SimpleForm没有(非模型形式)

时间:2011-03-03 13:13:16

标签: ruby-on-rails ruby-on-rails-3 simple-form

是否可以在没有模型的情况下使用Simple Form(by:Plataformatec)?

https://github.com/plataformatec/simple_form

5 个答案:

答案 0 :(得分:113)

您可以使用:symbol作为第一个参数。

<%= simple_form_for :user, url: users_path do |f| %>
  <%= f.input :name, as: :string %>
  ...
<% end %>

它将输出如下内容:

<form novalidate="novalidate" class="simple_form user" action="/users" accept-charset="UTF-8" method="post">
  ...
  <div class="input string required user_name">
    <label class="string required" for="user_name">
      <abbr title="required">*</abbr> Name
    </label>
    <input class="string required" type="text" name="user[name]" id="user_name" />
  </div>
  ...
</form>

答案 1 :(得分:16)

不幸的是,simple_form依赖于使用模型。基本上,有一些像simple_form_tag和input_tag方法等同于rails * _tag帮助器的东西会很好。在那之前,有一个简单的工作。

在表单中使用符号而不是类,并显式传递值以防止simple_form尝试访问模型属性。

<%= simple_form_for :user, :url => '/users' do |f| %>
  <%= f.text_field :name, input_html: { value: nil } %>
<% end %>

这样可以避免undefined method 'name' for User错误。

答案 2 :(得分:9)

您还可以在表单模型中使用模型外部的字段,使用simple_fields_for,如下所示:

<%= simple_form_for @user do |f| %>
  <%= f.input :name %>

  <%= simple_fields_for :no_model_fields do |n| %>
    <%= n.input :other_field %>
  <% end %>
<% end %>

这是一个简单实用的解决方案,因为您可以从不同模型创建不同类型的字段或不使用模型

答案 3 :(得分:4)

您还可以传递:symbol代替@object作为simple_form_for的参数。

<%= simple_form_for :email, :url => '/post_email' do |f| %>
  <%= f.input :subject, :as => :string %>
<% end %>

哪个会输出:

<form method="post" class="simple_form email" action="/post_email" accept-charset="UTF-8">
  ...
  <input type="text" size="30" name="email[subject]" id="email_subject">
</form>

请注意以下缺点:

  • 您将无法利用自动模型验证
  • 需要明确定义:url以及每个input
  • 的类型

答案 4 :(得分:4)

上面的所有方法仍然会将表单数据嵌套在“user”或任何作为第一个参数传递的符号中。这很烦人。

要模仿simple_form的样式/好处,但删除对象/符号依赖项和强制数据嵌套,可以创建局部。

HAML示例:

表单视图:

= form_tag("path/to/action", method: "POST") do
    = render "path/to/partial/field", type: "string", required: true, item: "first_name"

field部分:

- required_string = required ? "required" : ""
%div{class: "input #{type} #{required_string} #{item}"}
  %label{class: "#{type} #{required_string}", for: "#{item}"}
    - if required
      %abbr{title: "required"}
        *
    = t("application.#{item}")
  %input{name: "#{item}",                                                     |
    placeholder: t("application.#{item}"),                                    |
    type: "#{type}",                                                          |
    required: required,                                                       |
    "aria-required" => "#{required}" }