我已经遵循嵌套形式(第1部分和第2部分)上的railscasts情节,并且难以使用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%知道它为什么能工作,但是我相信它与rails 3无关,不再具有link_to_function。希望这个帮助

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

10-11 11:03
查看更多