javascript - 通过 jQuery 表单 railscasts 剧集以嵌套形式添加字段的问题

标签 javascript jquery ruby-on-rails-3 nested-forms

我关注了嵌套表单上的 railscasts 剧集(第 1 部分和第 2 部分)并且使用 jquery 添加字段时遇到困难,但是当我单击删除字段链接时,该字段被删除。 这是代码。
在我的问题模型中有

class Question < ActiveRecord::Base
has_many :tags, :class_name => "Tag", :dependent => :destroy, :foreign_key => "question_id"
accepts_nested_attributes_for :tags, :reject_if => lambda { |a| a[:keyword].blank? }, :allow_destroy => true

在我的标签模型中我有

class Tag < ActiveRecord::Base
    attr_accessible :keyword, :question_id
    belongs_to :question, :class_name => "Question", :foreign_key => 'question_id'
end

在我的问题表单中有

<%= form_for @question, :url => { :controller => "questions", :action => "create" } do |f| %>
    <%= f.label(:name, "Request Question:") %>&nbsp;&nbsp;
    <%= f.text_field(:name, :size => 72, :maxlength => 120) %><br />
    <%= f.fields_for :tags, :url => { :controller => "tags", :action => "create" } do |builder| %>
        <%= render "tag_fields", :f => builder %>
    <% end %>
    <p><%= link_to_add_fields "Add new tag", f, :tags %></p>
<% end %>

在我的 tag_fields 部分

<p class="fields">
    <%= f.label(:keyword, "Keywords:") %>&nbsp;&nbsp;
    <%= f.text_field(:keyword, :size => 20, :maxlength => 25) %>
    <%= link_to_remove_fields "remove", f %>
</p>

在 application_helper.rb 中

module ApplicationHelper
def link_to_remove_fields(name, f)
    f.hidden_field(:_destroy) + link_to_function(name, "remove_fields(this)")
end

def link_to_add_fields(name, f, association)
    new_object = f.object.class.reflect_on_association(association).klass.new
    fields = f.fields_for(association, new_object, :child_index => "new_#{association}") do |builder|
        render(association.to_s.singularize + "_fields", :f => builder)
    end
    link_to_function(name, h("add_fields(this, \"#{association}\", \"#{escape_javascript(fields)}\")"))
end
end

然后终于在我的 application.js 中

function remove_fields(link) {
    $(link).prev("input[type=hidden]").val("1");
    $(link).closest(".fields").hide();
}

function add_fields(link, association, content) {
    var new_id = new Date().getTime();
    var regexp = new RegExp("new_" + association, "g")
    $(link).parent().before(content.replace(regexp, new_id));
}

我已经检查过文件是否包含在页面源代码中。 jquery 有效是因为 我的应用程序的其他部分正在运行。单击添加新标签时,我没有收到任何错误。 我看过其他解决方案,但没有一个对我有用。我似乎无法添加字段。 感谢您的帮助

最佳答案

我设法解决了这个问题,但我不确定这是否是最好的方法。
application_helper.rb 中,我从这行更改了以下行

link_to_function(name, h("add_fields(this, \"#{association}\", \"#{escape_javascript(fields)}\")"))

对此

link_to_function(name, "add_fields(this, '#{association}', '#{escape_javascript(fields)}')", :remote => true)

我不是 100% 确定它为什么起作用,但我相信它与不再具有 link_to_function 的 Rails 3 有关。希望这有帮助

关于javascript - 通过 jQuery 表单 railscasts 剧集以嵌套形式添加字段的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6505267/

相关文章:

javascript - 普通对象 Mongoose 不适用于排序

javascript - 带有服务器集成的 PayPal 客户端 JavaScript SDK - 设置付款金额

ruby-on-rails-3 - 为什么考虑_all_requests_local 使用 rspec 配置失败

JavaScript 返回未定义

javascript - 如何在提交无效表单后保留到页面(CodeIgniter 3)

javascript - jqWidget CheckBox 在网格捕获复选框变化

用于 php 的 phpMyAdmin 日期时间选择器

javascript - 为什么我的 JavaScript 代码收到“"No ' Access-Control-Allow-Origin' header is present on the requested resources”错误,而 Postman 却没有?

ruby-on-rails-3 - 如何在此文件中使用 "Form_tag"而不是 "Form_for"

ruby-on-rails-3 - Rails 3 - form_for 复数化在 "new"操作上导致路径/方法错误,但在 "edit"上没有