是否可以在没有模型的情况下使用简单表单(作者:Plataformatec)?
也许[我对另一个问题的回答] [1]可以帮助您。[1]:stackoverflow.com/a/14659270/157816
—
baxang
是否可以在没有模型的情况下使用简单表单(作者:Plataformatec)?
Answers:
您可以将其: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>
f.input :name, :as => :string
与标签,提示等,并生成通常的形式
undefined method 'name?' for nil:NilClass
至少为我提供了一个。
不幸的是,simple_form依赖于使用模型。本质上,拥有与它们的rails * _tag helper等效的诸如simple_form_tag和input_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
错误。
selected
代替value
以避免undefined method 'name' for Model
错误
您也可以为传递a:symbol
而不是@object
as参数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
上面的所有方法仍然使您保留嵌套在“用户”或您作为第一个参数传递的任何符号内部的表单数据。真烦人
要模仿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}" }