1

我的模型如下

class Question < ActiveRecord::Base
  ANSWERS= ['Option 1', 'Option 2', 'Option 3', 'Option 4']
end

在视图<%= select(:question, :answer, Question::ANSWERS, {:include_blank => true}) %>输出中

<select name="question[answer]" id="question_answer">
  <option value=""></option>
  <option value="Option 1">Option 1</option>
  <option value="Option 2">Option 2</option>
  <option value="Option 3">Option 3</option>
  <option value="Option 4">Option 4</option>
</select>

我试过<%= select(:question, :answer, Question::ANSWERS.collect {|d| [d, Question::ANSWERS.index(d)]}, {:include_blank => true}) %> 这会产生

<select name="question[answer]" id="question_answer">
  <option value=""></option>
  <option value="0">Option 1</option>
  <option value="1">Option 2</option>
  <option value="2">Option 3</option>
  <option value="3">Option 4</option>
</select>

但我需要以下输出

<select name="question[answer]" id="question_answer">
  <option value=""></option>
  <option value="1">Option 1</option>
  <option value="2">Option 2</option>
  <option value="3">Option 3</option>
  <option value="4">Option 4</option>
</select>
4

2 回答 2

3

在您的第二个示例中,使用:

<%= select(:question, 
           :answer, 
           Question::ANSWERS.collect {|d| [d, Question::ANSWERS.index(d) + 1]},
           {:include_blank => true}) %>
于 2010-11-22T12:04:43.630 回答
0

你可以用这样的哈希键值对修改你的数组

ANSWERS= [1=>'Option 1', 2=>'Option 2', 3=>'Option 3', 4=>'Option 4']

现在使用 options_for_select 并获得所需的输出。

于 2014-05-26T06:34:48.327 回答