我已經遵循嵌套窗體上的railscasts插曲(第1部分和第2部分),並且難以使用jquery添加字段,但是當我單擊刪除字段鏈接時,字段獲取除去。 這是代碼。
在我的問題模型我有
問題通過jQuery形式添加字段嵌套的形式railscasts集
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:") %>
<%= 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:") %>
<%= 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
@Minnb嗨,謝謝,結帳我的答案,不知道爲什麼它的作品,但我認爲它與軌道3和link_to_function有關。起初我沒有收到任何html。不知道爲什麼? – Hishalv