Simple_form 2.0.2を使用する
HAMLを使用した簡単なフォームコード:
= f.input :remember_me, as: :boolean, inline_label: 'Remember me'
しかし、これはこれをレンダリングします:
<div class="control-group boolean optional">
<label class="boolean optional control-label" for="admin_remember_me">Remember me</label>
<div class="controls">
<input name="admin[remember_me]" type="hidden" value="0" />
<label class="checkbox"><input class="boolean optional" id="admin_remember_me" name="admin[remember_me]" type="checkbox" value="1" />Remember me</label>
</div>
</div>
インラインラベルのみを持つように、レンダリングされた最初のラベルを削除するにはどうすればよいですか?
次を使用できます。
= f.input :remember_me, as: :boolean, inline_label: 'Remember me', label: false
グーグルのfuの後、解決策を見つけました。
使用する input_field
の代わりにinput
の代わりに、ラベルを自動的に生成しません。
= f.input_field :remember_me, as: :boolean, inline_label: 'Remember me'
それが機能しない人
= f.input_field ...
この方法を使用します
= f.check_box ...
Simple_form 2.1.0およびRails 3.0.20では、ここにリストされたソリューションはいずれも機能しませんでした(f.input_fieldは、敗北を認めているため使用しません)。
不足している部分はboolean_styleオプションです。
options.merge!({label: false, boolean_style: :inline})
このためのカスタム入力を作成することをお勧めします(例:inline_checkbox)
boolean_styleは、デフォルトで:nestedとして設定されています。
# Defaults to :nested for bootstrap config.
# :inline => input + label
# :nested => label > input
config.boolean_style = :nested
.control-group.error .help-inline {
display: none;
}
これは動作するはずです、Rails 3.2およびsimple_form 2.x +で動作します
遅すぎるかもしれませんが、gamovの答えに触発されて、これを初期化ファイルのインラインbootstrapチェックボックス 'config/simple_form_bootstrap.rb'からのカスタムラッパーにしました:
config.wrappers :horizontal_radio_and_checkboxes, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
b.use :html5
b.optional :readonly
b.use :label, class: 'col-sm-3 control-label'
b.use :input
b.use :error, wrap_with: { tag: 'span', class: 'help-block' }
b.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
end
このhtmlを生成します:
<div class="form-group boolean optional user_admin">
<label class="boolean optional col-sm-3 control-label" for="user_admin">Admin</label>
<div class="col-sm-9 checkbox-inline">
<input name="user[admin]" value="0" type="hidden">
<input class="boolean optional" id="user_admin" name="user[admin]" value="1" type="checkbox">
</div>