将ActionView :: Helpers :: FormBuilder传递给部分

时间:2011-09-01 15:42:38

标签: ruby-on-rails forms ruby-on-rails-3.1 actionview formbuilder

我正试图在给定某个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

3 个答案:

答案 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分开。