我有模型Search,Color和ColorsSearch:
def Search
has_many :colors, :through => :colors_searches
end
def Color
has_many :searches, :through => :colors_searhes
end
def ColorsSearch
belongs_to :color
belongs_to :search
end
在我看来,我希望有多个颜色的checbox,当用户提交表单时,会使用colors_serches记录创建一个新的搜索记录(每个颜色选择一个)。
<% Color.with_products.order(:name).each do |color| %>
<% if color.name != 'none' %>
<div class="checkbox">
<input type="checkbox" name="search[color_id]" value="<%= color.id %>" id="color-checkbox-<%= color.id %>">
<label for="color-checkbox-<%= color.id %>" style="background-color: <%= color.hex %>;"></label>
</div>
<% end %>
<% end %>
感谢您的想法, 米罗
以下代码应该完成我正在寻找的大部分解决方案,唯一剩下的部分是:
根据“颜色”字段为每个生成的标签动态设置背景颜色。模型Color有一个属性:hex,它存储颜色的十六进制标识,例如:#FFFFFF表示白色等。
<%= s.association :colors, collection: Color.with_products.order(:name), label: false, as: :check_boxes %>
我需要与此代码类似的东西,因此对于每种颜色,我会设置不同的背景颜色:
<%= s.association :colors, collection: Color.with_products.order(:name), label: false, as: :check_boxes, :label_html => { :style => "background-color: #{:hex};" } %>
所以我找到了两个解决方案(可能不那么优雅,但它们有效):
我的观点:
<%= s.association :colors, collection: Color.collection_for_filter, label: false, as: :check_boxes %>
颜色模型:
def self.collection_for_filter
array = []
Color.with_products.each { |c| array << ["#{c.id}", "#{c.id}", { :style => "background-color: #{c.hex}" }] }
array
end
我迭代所有颜色,对于每种颜色,我使用我需要的自定义值渲染输入和标签。
<% Color.with_products.each do |color| %>
<div class="checkbox">
<input class="check_boxes optional" type="checkbox" value="<%= color.id %>" name="search[color_ids][]" id="search_color_ids_<%= color.id %>">
<label class="collection_check_boxes" style="background-color: <%= color.hex %>" for="search_color_ids_<%= color.id %>">
</label>
</div>
<% end %>
我选择了选项2,因为它似乎更好的解决方案而不需要使用JavaScript。
答案 0 :(得分:0)
以下代码应该完成我正在寻找的大部分解决方案,唯一剩下的部分是:
请参阅UPDATE以获取代码参考。