【问题标题】:Problems adding fields in nested form through jQuery form railscasts episode通过 jQuery 表单 railscasts 插曲以嵌套形式添加字段的问题
【发布时间】:2011-06-28 10:50:03
【问题描述】:

我已经关注了嵌套表单(第 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 之所以有效,是因为 我的应用程序的其他部分正在运行。单击添加新标签时,我没有收到任何错误。 我看过其他解决方案,但没有一个对我有用。我似乎无法添加字段。 感谢您的帮助

【问题讨论】:

  • 点击添加标签时是否会弹出html? (比如没有注入到文档中的文本格式的 html)或者什么都没有?
  • @Msencenb 嗨,谢谢,查看我的答案,不知道它为什么有效,但我认为它与 rails 3 和 link_to_function 有关。起初我没有得到任何 html。不知道为什么?

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


【解决方案1】:

我设法解决了这个问题,但我不确定这是否是最好的方法。
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 有关。希望对您有所帮助

【讨论】:

  • 我认为 link_to_function 仍然存在于 rails 3 中(您在应用程序助手中使用它)但是看起来 html 清理函数 (h) 以某种方式搞砸了。我鼓励你在没有遥控器的情况下测试它 => :true 但也没有 h 我相信它应该可以工作
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-03-01
  • 1970-01-01
  • 1970-01-01
  • 2023-02-17
相关资源
最近更新 更多