我正在制作一个简单的应用程序,应该使用rails 4动态删除字段,我基本上是按照 rails cast tutorial 这样做的。 ,但它在 Rails 3 中,感谢上帝,我设法解决了大部分问题,但我陷入了这个困境,删除链接显示正确,但它不起作用!
当我转到localhost:3000/survey/new
时,一切看起来都正常,删除链接也应如此
当我单击删除网址时,只需将 localhost:3000/survey/new
更改为 localhost:3000/survey/new#
这是我的代码的一部分,我认为它与删除链接相关
#_form.html.erb
<%= f.fields_for :questions do |ff| %>
<div class="field">
<%= render 'question_fields', :f => ff %>
</div>
<% end %>
<小时/>
#_question_field.html.erb
<div class="field">
<p>
<%= f.label :content , "question"%><br>
<%= f.text_area :content %>
<%= link_to_remove_fields "remove", f %>
</p>
</div>
<小时/>
module ApplicationHelper
def link_to_remove_fields(name, f)
f.hidden_field(:_destroy) + link_to_function(name, "remove_fields(this)")
end
end
<小时/>
#application.js
//= require jquery
//= require jquery_ujs
//= require turbolinks
//= require_tree .
function remove_fields(link) {
$(link).previous("input[type=hidden]").value = "1";
$(link).parent(".fields").hide();
}
<小时/>
任何帮助,因为我不知道该做什么或缺少什么
最佳答案
Railscast 有几个缺陷 - 最突出的是它只允许将单个表单元素附加到页面(它使用表单元素预加载 JS 链接并不断将相同的元素放到页面上 - 问题是这个元素与其他人具有相同的 id
)
一个better tutorial can be found here (uses child_index
)
我强烈建议您查看Cocoon gem
您将能够通过上面的链接看到它是如何工作的,但最重要的是您将能够使用它来调用您需要的任意数量的新表单元素:link_to_add_association
,或link_to_remove_association
关于javascript - Rails 4 嵌套属性 link_to_function,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23055111/