是否可以在没有模型的情况下使用Simple Form(by:Plataformatec)?
答案 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}" }