Change html form id generated by form_for rails 3.1

こ雲淡風輕ζ 提交于 2019-12-20 16:10:37

问题


I have this form_for:

<%= form_for [post, Comment.new,], :remote => true do |f| %>
<%= f.text_area :content, :cols =>10, :rows => 1%>
<% end %>
<%= f.submit :class => "input_comment"  %>

That generate the next code html:

<form method="post" id="new_comment" data-remote="true" class="new_comment" 
action="/post/4efcda9e1d41c82486000077/comments" accept-charset="UTF-8"><div 
style="margin:0;padding:0;display:inline"><input type="hidden" value="✓" name="utf8">
<input type="hidden" value="ctVfDF/O4FIR91I7bC5MVezQmutOCkX3dcXe73uNPZY=" name="authenticity_token">

<textarea rows="1" name="comment[content]" id="comment_content" cols="10"></textarea>
<input type="submit" value="Create Comment" name="commit" class="input_comment">
</form>

If I have many forms in a same page is not a html valid with the same id.

  • The id for form_for generate id="new_comment"
  • The id for textarea generate id="comment_content"

With so many forms in a same page is not valid html.

How can I change the id autogenerate by form_for method helper from rails 3.1?


回答1:


Adding on to what miked said, the easiest way to make unique form id's for the posts would be to use the post's id numbers in the id attribute, like so:

<%= form_for [post, Comment.new,], :remote => true, :html => { :id => "new_comment_on_#{post.id}" } do |f| %>



回答2:


I think the :namespace option is what you're looking for.

It appends the name to the form's id as well as all input and label fields.

e.g

<%= form_for [post, Comment.new,], namespace: 'NAMESPACE', :remote => true do |f| %>
    <%= f.text_area :content, :cols =>10, :rows => 1%>
<% end %>

Would generate:

Form id = NAMESPACE_new_comment

Textarea id = NAMESPACE_comment_content

From the docs:

:namespace - A namespace for your form to ensure uniqueness of id attributes on form elements. The namespace attribute will be prefixed with underscore on the generated HTML id




回答3:


You should be able to set the form's id to whatever you want. Something like:

<%= form_for @object, :html=> {:id => 'custom_form_id'} do |f| %>


来源:https://stackoverflow.com/questions/8682076/change-html-form-id-generated-by-form-for-rails-3-1

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!