我正试图在给定某个AJAX请求的情况下以动态方式创建表单元素。
这是我的设置:
查看:
<%= link_to 'Next', check_unique_id_students_path, :remote => true %>
<div id="guardian_student_details"></div>
控制器:
def check_unique_id
@student = Student.new
@this_form = ActionView::Helpers::FormBuilder.new(:student, @student, @template, {}, proc{})
end
JS:
jQuery("#guardian_student_details").html("<%=escape_javascript(render :partial => "student_details", :locals => { :s => @this_form }) %>");
部分:
<% puts s.text_field :first_name %>
<% puts s.field_helpers %>
出于调试目的,我在我的部分开头放置了以下几行:
<% puts s.class.to_s %>
<% puts s.object.to_s %>
打印出来:
ActionView::Helpers::FormBuilder
Student
这应该有效。但是rails会出现以下错误:
ActionView::Template::Error (undefined method `text_field' for nil:NilClass):
1: <% puts s.class.to_s %>
2: <p>
3: <%= s.text_field :first_name, :class => 'text_input is_empty' %>
4: <%= s.label :first_name %><strong>*</strong>
5: </p>
6:
app / views / students / _student_details.html.erb:3:in _app_views_students__student_details_html_erb__2485891544130782916_2214680440'
app/views/students/check_unique_id.js.erb:2:in
_ app_views_students_check_unique_id_js_erb__3504800328150418937_2214933160'
这意味着“s”是NIL,之前我只验证了2行。有人有什么想法吗?我不知道这是否与控制器中初始化的“@template”变量有关。我玩过并接受几乎任何东西,如果打印的是零。 任何帮助,将不胜感激。感谢
最后的说明:
我试图实现这个:AJAX update of accepts_nested_attributes_for partials
答案 0 :(得分:4)
在视图中,我发现'view_context'在Rails 3.1中不起作用。而是在创建FormBuilder对象时尝试'self'。
s = ActionView :: Helpers :: FormBuilder.new(:student,@ student,self,{},proc {})
答案 1 :(得分:4)
对于需要在控制器中构建表单构建器的任何人,view_context仍然可以在那里工作。使用Rails 4.1.4:
@object = Object.new
@f = ActionView::Helpers::FormBuilder.new(:object, @object, view_context, {})
答案 2 :(得分:0)
在控制台中尝试:
s = ActionView::Helpers::FormBuilder.new(:student, @student, @template, {}, proc{})
s.text_field :first_name
您将遇到相同的错误。我认为问题来自你创建form_builder对象,即使我不知道确切的错误......
在我看来,你的解决方案有点复杂。您可以尝试这个解决方案:
#html.erb
<% form_for @student do |f| %>
<div id='guardian_student_details' class='hide-this-block'>
<%= render :partial => "student_details", :locals => { :s => f }) %>
</div>
<% end %>
#js
jQuery("#guardian_student_details").show();
一般来说,我更喜欢将javascript和ruby分开。