2011-03-03 117 views

回答

107

您可以使用: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> 
+0

那种毫无意义的,不是吗?当您使用回退文本字段生成器时,您不会获得simple_form_for的任何好处。 – toxaq

+3

@toxaq也许这不是一个好例子。您可以使用'f.input:name,:as =>:string'并生成标签,提示等常用形式。 – htanata

+6

奇怪的是,这正是我想要做的并且没有成功。你的例子给出了一个'未定义的方法'的名字?'至少为我零:NilClass'。 – toxaq

2

你也可以通过一个: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
+3

该选项仍然使用封面下的模型。该符号应与模型名称相匹配,它将解析为模型并创建一个新模型并将其用于每个字段,因此表单字段中使用的属性实际上应该存在于模型中。 –

13

不幸的是,simple_form依赖于使用模型。从本质上来说,像simple_form_tag和input_tag方法等价于它们的rails * _tag helper会很好。在此之前,有一个简单的工作。

在表单中使用符号而不是类,并显式传递该值以防止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

这对我有效:<%= f.input:create_key,input_html:{value:nil},required:true,hint:“仅通过邀请,查看电子邮件中的关键字”%> – codenoob

+1

如果使用集合,选择“而不是”值“,以避免'模型'错误'未定义的方法'名称' –

3

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

要模仿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}" } 
6

也可以使用在模型外字段的表单模型内,与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 %> 

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