Ruby on Rails - 在text_field中添加CSS

5

我在Rails中创建了一个表单,当我为text_field添加CSS类时,表单将无法提交。

我还是Rails的新手,任何帮助都会非常感激。

这是我的表单:

<% @page_title = "Contact" %>
    <hr>
    <div class="col-lg-12">
                <h1 class="page-header">
                    BK Legal Courier Corp <br />Call BK @ <span style="color:#47B224">613-286-8265</span>
                </h1>
            </div>

<hr>
<div class="container">
  <h2>Contact Us</h2>
   <%= form_for :fc, :url => {:action => 'create'} do |f| %>
    <div class="form-group">
      <%= f.label :first_name %>
      <%= f.text_field (:first_name, :class => 'form-control')%>
    </div>
    <div class="form-group">
      <%= f.label :last_name %>
     <%= f.text_field (:last_name, :class => 'form-control') %>
    </div>
     <div class="form-group">
      <%= f.label :email %>
      <%= f.text_field (:email, :class => 'form-control') %>
    </div>
     <div class="form-group">
  <%= f.label :comment %>
 <%= f.text_area (:comment, :class => 'form-control') %>
</div>
<div class="form-group">
  <%= f.label :referral %>
        <%= f.select (:referral, [['Friends', 1], ['News', 2], ['Online', 3], ['Other', 4]], :class => 'form-control')%>
</div>
 <%= submit_tag ("Submit") %>
  </form>
</div>

<% end %>
</body>

</html>

问题是,如果表单中没有:class => "form-control",则表单将无法提交。我必须在每个表单字段变量周围加上括号。
这是我的routes.rb文件:
    Rails.application.routes.draw do
  root "home#index"


  match ':controller(/:action(/:id))', :via => [:get, :post]

    end

这是我的控制器:

    class HomeController < ApplicationController
     def home
        render("home/index")
     end
      def new
@fc = FeedbackCustomer.new
  end
  def create
     # Instantiate a new object using form parameters
    @fc = FeedbackCustomer.new(feedbackcustomer_params)
if @fc.save
    redirect_to(:action => "home")
end
  end

  def application

  end

private

def feedbackcustomer_params
params.require(:fc).permit(:first_name, :last_name, 
    :email, :comment, :referral)
    end
end

任何帮助都将不胜感激。谢谢!
2个回答

6
如果您正在使用Ruby 1.9+,那么这应该可行:
<%= f.text_field :last_name, class: 'form-control' %>

如果您使用的版本早于1.9,则应该可以使用以下方法:
<%= f.text_field :last_name, :class => 'form-control' %>

如需更多信息,您可以使用ActionView::Helpers::FormTagHelper API文档

表单助手Rails指南也可能对您有所帮助。


3

对于最新版本的Ruby,现在也可以这样做:

<%= f.text_field :last_name, class: 'form-control' %>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接