0

我想在我的网页页脚创建一个用于注册邮件列表的表单。我所做的是创建一个在应用程序布局的页脚中呈现这个小表单的部分。

这是部分的代码:

<%= form_for(@mailing_list) do |f| %>
  <% if @mailing_list.errors.any? %>
    <div id="error_explanation">
      <h2><%= pluralize(@mailing_list.errors.count, "error") %> prohibited this mailing_list from being saved:</h2>

      <ul>
      <% @mailing_list.errors.full_messages.each do |msg| %>
        <li><%= msg %></li>
      <% end %>
      </ul>
    </div>
  <% end %>

  <div class="field">
    <%= f.label :first_name %><br />
    <%= f.text_field :first_name %>
  </div>
  <div class="field">
    <%= f.label :last_name %><br />
    <%= f.text_field :last_name %>
  </div>
  <div class="field">
    <%= f.label :email %><br />
    <%= f.text_field :email %>
  </div>
  <div class="actions">
    <%= f.submit %>
  </div>
<% end %>

我还在学习rails,所以这是从脚手架生成的代码。根据我收集的信息,我需要使用 @mailing_list = MailingList.new 实例化 @mailing_list 变量,但这里的问题是邮件列表控制器中的 NEW 操作不会被调用,因为我不一定要访问该页面。此表单位于每一页的页脚中。

创建此表单的正确方法是什么?有没有办法在每个控制器中不调用 MailingList.new 的情况下做到这一点?

谢谢!

4

2 回答 2

2

将您的表格更改为此

<%= form_for MailingList.new, html: { remote: true } do |f| %>

所以你不必担心实例变量。您还应该通过remote: true,以便通过 ajax 提交表单。要显示错误,请创建一个名为create.js.erbunder的文件app/views/mailing_lists并添加以下内容(只是一个在表单前附加错误的简单脚本)

$('.error-messages').remove();
<% if @mailist_list.errors.any? %>
  $('#new_mailing_list').before('<ul class="error-messages"></ul>');
  <%= @mailing_list.errors.full_messages.each do |msg| %>
    $('.error-messages').append('<li><%= escape_javascript msg %></li>');  
  <% end %>
<% end %>
于 2013-03-18T00:36:53.147 回答
0

您可以将form_for方法更改为:

<%= form_for :mailing_list, url: mailing_lists_path do |f| %>

然后您不再需要@mailing_list为每个页面进行初始化。

需要注意的是,您不能在页脚中呈现错误。您需要new.html.erb使用问题中的代码创建一个视图,如果在创建操作中保存时出现任何错误,则可以呈现该视图。

于 2013-03-17T22:47:48.690 回答