3

grouped_collection_select接受九个参数,包括一个选项属性。如何在选项中添加自定义属性,即数据标记,以在选择选项时使用?

选择现在编码为:

= f.grouped_collection_select :course_id, Discipline.order(:name), :courses, :name, :id, :display

我想添加一个自定义数据属性,以便输出如下:

<select id="enrollment_course_id" name="enrollment[course_id]">
    <option selected="selected" value="7" data-duration=8>Introduction to Guitar (8 weeks)</option>
    <option value="8" data-duration=8>Strings 1-3 (8 weeks)</option>
    <option value="9" data-duration=10>Strings 4-6 (10 weeks)</option>
    <option value="10" data-duration=12>Basic Chords (12 weeks)</option>
</select>

我们如何以编程方式生成自定义属性?

4

1 回答 1

2

似乎没有很好的和正确记录的方法来做到这一点。

解决方案 1.使用 grouped_collection_select 的未完全记录的功能:

f.grouped_collection_select :course_id, Discipline.order(:name), :courses_with_duration_data, :name, ->(el){el.first.id}, ->(el){el.first.display}

你需要courses_with_duration_data像这样实现的地方:

class Discipline
  has_many :courses
  def courses_with_duration_data
    courses.map {|course| [course,{data: {duration: course.duration}}]}
  end
end

它依赖于如果您将数组数组传递给options_for_select数组中的哈希将被视为 html 选项。

将与视图相关的方法放入模型的缺点。而且它可能会在未来的 Rails 版本中中断,因为 grouped_collection_select 上没有记录这种用法,所以你最好自己生成选项。

解决方案 2.自己重新实现选项:

option_groups_from_collection_for_select在助手中重新实现自定义。这可能看起来像这样:

def options_for_disciple_with_courses(disciplines)
  disciplines.map do |discipline|
    option_tags = options_for_select(
      discipline.courses.map {|course| [course.display, course.id, {data: {duration: course.duration}}]}
    )
    content_tag(:optgroup, option_tags, label: discipline.name)
  end.join.html_safe
end

你的观点会变成:

f.select :course_id, options_for_disciple_with_courses(Discipline.order(:name))
于 2016-01-02T21:23:59.673 回答