【发布时间】:2015-05-21 05:39:00
【问题描述】:
我将 simple_form 与引导包装器一起使用,但不知道该怎么做。
我想生成这样的输入:
<div class="form-group string optional event_start_time_date ">
<label class="string optional control-label" for="event_start_time_date">Start date</label>
<div class="input-group date" id="date_picker">
<input class="string required form-control" type="text" name="event[start_time_date]" id="event_start_time_date">
<span class="input-group-addon">
<span class="glyphicon glyphicon-calendar"></span>
</span>
</div>
</div>
我的包装看起来像这样:
config.wrappers :input_group, tag: 'div', class: 'form-group', error_class: 'has-error' do |b|
b.use :label, class: 'control-label'
b.wrapper :input_group_div, tag: 'div', class: 'input-group' do |ba|
ba.use :input, class: 'form-control'
end
b.use :error, wrap_with: { tag: 'span', class: 'help-block' }
b.use :hint, wrap_with: { tag: 'p', class: 'help-block' }
end
对于
<%= f.input :start_time_date, as: :string, required: false, label: "Start date", wrapper: :input_group, :input_group_div_html {class: "date", id: "date-picker"} %>
它生成下面的 html 输出:
<div class="form-group string optional event_start_time_date">
<label class="string optional control-label" for="event_start_time_date">Start time</label>
<div class="input-group date" id="date-picker">
<input class="string optional form-control" type="text" name="event[start_time_date]" id="event_start_time_date">
</div>
</div>
现在的区别:
-
<span class="input-group-addon">这个是必须的,应该由wrapper生成,但是不知道怎么在wrapper中生成。 -
<span class="glyphicon glyphicon-calendar"></span>- 不同的输入组在这里将有不同的类和不同的跨度文本,最好我可以将它作为<%= f.input ...中的某个选项传递
【问题讨论】:
-
有一种更简洁的方法可以解决这个问题。 Check this other question for reference
标签: ruby-on-rails twitter-bootstrap ruby-on-rails-4 simple-form