Returns a string of option tags that have been compiled by iterating over
the collection and assigning the result of a call to the
value_method as the option value and the
text_method as the option text.
options_from_collection_for_select(@people, 'id', 'name')
# => <option value="#{person.id}">#{person.name}</option>
This is more often than not used inside a select_tag like this example:
select_tag 'person', options_from_collection_for_select(@people, 'id', 'name')
If selected is specified as a value or array of values, the
element(s) returning a match on value_method will be selected
option tag(s).
If selected is specified as a Proc, those members of the
collection that return true for the anonymous function are the selected
values.
selected can also be a hash, specifying both
:selected and/or :disabled values as required.
Be sure to specify the same class as the value_method when
specifying selected or disabled options. Failure to do this will produce
undesired results. Example:
options_from_collection_for_select(@people, 'id', 'name', '1')
Will not select a person with the id of 1 because 1 (an Integer) is not the same as '1' (a string)
options_from_collection_for_select(@people, 'id', 'name', 1)
should produce the desired results.
Please login to continue.