<div class="row">
<div class="btn-group" data-toggle="buttons">
<%= f.collection_radio_buttons :tqn, [["1", '特区内'] ,["0", '特区外']], :first, :last, { item_wrapper_tag: false } do |b| %>
<%= b.label(:class => 'btn btn-primary'){ b.radio_button + b.text } %>
<% end %>
</div>
</div>
产生的html 代码是 :
<div class="btn-group" data-toggle="buttons">
<label class="btn btn-primary active" for="gis_region_tqn_1">
<input id="gis_region_tqn_1" name="gis_region[tqn]" type="radio" value="1">特区内
</label>
<label class="btn btn-primary" for="gis_region_tqn_0">
<input checked="checked" id="gis_region_tqn_0" name="gis_region[tqn]" type="radio" value="0">特区外
</label>
</div>
其中注意的几个要点:
1.
<div class="btn-group" data-toggle="buttons">
data-toggle="buttons"
是为了符合 bootstrap.js 中按钮单选的功能
2.
{ item_wrapper_tag: false } do |b| %>
<%= b.label(:class => 'btn btn-primary'){ b.radio_button + b.text } %>
<% end %>
定制 simple_form 中产生的 radio 的html
详细api 参考:
http://rubydoc.info/github/plataformatec/simple_form/SimpleForm/FormBuilder:collection_radio_buttons