繁体   English   中英

Rails Ajax局部传递表单生成器

[英]Rails Ajax partials passing form builder

我将使用下拉列表的值用ajax加载表单的一部分,如下所示:

..form_partial.js.erb

 $('#custom_ajax').remove();
  <% if @house == "Rent" %>
   $('#rest_of_form').after('<div id="custom_ajax"><%= escape_javascript render('/houses/forms/rent') %></div>');
 <% else %>
   $('#rest_of_form').after('<div id="custom_ajax"><%= escape_javascript render('/houses/forms/buy') %></div>');
<% end %>

这里叫...

.._form.html.erb
<%= form_for @house, :validate => true, :html => { :class => 'form-horizontal',:multipart => true } do |f| %>

..........................................
..........................................

<div id = "rest_of_form"></div>
<div id="custom_ajax">
..........................................
..........................................

</div>
..........................................
..........................................
<script type="text/javascript">
$(document).ready(function() {
  $('#house_listing_type').change(function() {


$.ajax({ url: '/houses/' + this.value + '/form_partial' });

});
});
</script>

然后,我可以用它来加载文件,它的工作非常好,唯一的问题是我需要将表单生成器传递给局部文件,因为我的_buy.html.erb看起来像这样

  <div class="control-group">
    <%= label :property_classification, "Property Classification", :class => "control-label" %>
      <div class="controls">
          <div class="input-prepend">
        <span class="add-on"><i class="icon-info-sign"></i></span>
          <%= select :property_classification, ["Residential","Commercial"], {},{:class=>"input-medium"} %>
        </div>
      </div>
    </div>

显然需要表单生成器,我尝试将其作为本地等传递,但无济于事。 我也尝试删除所有的“ f”。 这行得通,但是表单显示不正确,并且没有任何高级表单构建器元素起作用。

我如何才能将表单生成器添加到局部视图?

谢谢

http://api.rubyonrails.org/classes/ActionView/Helpers/FormTagHelper.html
当不依赖form_for ,要使用的表单构建器元素分别是label_tagselect_tag

在这种情况下,您可能会发现同时使用form_tagfields_for比使用form_for更容易。

我在这里提出的解决方案回答了相同的问题:

在rails的remote_function中通过表单生成器?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM