ruby - simple_form 的 collection_radio_button 和自定义标签类

标签 ruby simple-form

我正在尝试使用 FontAwesome 制作带有 radio 收集的星级评分表,为此我实际上需要更改由 simple_form 生成的 collection_radio_button 输入的标签类,但找不到任何明显的解决方案。

到目前为止我使用:

form_for @user do |f|
  f.collection_radio_buttons :rating, [[1, 'Bad'] ,[2, 'Ok'], [3, 'Great']],
                             :first, :last, { item_wrapper_tag: false }
end

生成:

<input id="review_rating_1" name="review[rating]" type="radio" value="1" />
<label class="collection_radio_buttons" for="review_rating_1">Bad</label>
<input id="review_rating_2" name="review[rating]" type="radio" value="2" />
<label class="collection_radio_buttons" for="review_rating_2">Ok</label>
<input id="review_rating_3" name="user[options]" type="radio" value="3" />
<label class="collection_radio_buttons" for="review_rating_3">Great</label>

但我希望标签有一个额外的类,例如:

<input id="review_rating_3" name="user[options]" type="radio" value="3" />
<label class="collection_radio_buttons icon-star" for="review_rating_3">Great</label>

更新:此类静态定义于:https://github.com/plataformatec/simple_form/blob/master/lib/simple_form/tags.rb#L43

最佳答案

这可以通过使用 block 来实现:

form_for @user do |f|
  f.collection_radio_buttons :rating, [[1, 'Bad'] ,[2, 'Ok'], [3, 'Great']],
                             :first, :last, { item_wrapper_tag: false } do |b|
    b.radio_button + b.label(:class => "collection_radio_buttons icon-star")
  end
end

此文档可以展示一些其他示例:http://rubydoc.info/github/plataformatec/simple_form/SimpleForm/FormBuilder:collection_radio_buttons

关于ruby - simple_form 的 collection_radio_button 和自定义标签类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17190111/

相关文章:

ruby-on-rails - 渲染布局而不在 Rails 中加载其内部布局

ruby - 如何使用 mechanize/nokogiri 获得简单但格式化的 html?

css - Rails Simple Form Bootstrap - 复选框内联垂直对齐

ruby-on-rails - Rails 4 嵌套表单 Simple_form_for 和 simple_field_for

Ruby:如果存在 ENV 变量,则使用最简洁的方法,否则使用默认值

ruby - 多线程循环

arrays - 遍历 Ruby 中的哈希数组(解析 JSON)

ruby - 简单形式 : Remove outer label for an inline checkbox with label

javascript - 使用 CoffeeScript 动态添加字段到 simple_form

ruby-on-rails - Rails simple_form gem 正在为预填充的输入添加绿色边框