2

我遇到的问题是我的选择字段选项没有传递要保存的属性参数;但是,如果选择更改为 text_field,则该字段会保存。所以这个问题似乎在我看来。r.fields_for 的其他部分也都在保存。

看法

<%= f.fields_for (:report) do |r| %>
<%= r.select :report_status, ['Ordered', 'Received'], :include_blank => 'Select One' %>
<label for="report_status">Report Status</label>

在嵌套模型的编辑操作中,此选择工作正常,唯一的区别是表单。

我还尝试以更详细的方式进行设置:

<% report_array = ['Select', 'Ordered', 'Received'] %>
<%= r.select(:report_status, options_for_select(Array[*report_array.collect {|v,i| [v,report_array.index(v)] }])) %>

它根本没有通过它们,甚至没有空白。有什么想法可能导致这种情况吗?

更新:

HTML 输出

<select name="project[report_attributes][report_status]" id="project_report_attributes_report_status" class="initialized"><option value="0">Select</option> <option value="1">Ordered</option> <option value="2">Received</option></select>
4

2 回答 2

1

这个问题与 MaterializeCSS 有关,这是我选择尝试的一个较新的前端框架。我应该删除所有可能的因素。我不认为这是在扮演一个角色。所以我将 browser-default 应用为 { :class => "browser-default" },瞧。它得救了。

这是一个解决方案仍然让我感到困惑,因为选择在使用 materializecss 选择的编辑时工作正常。但我想我见过奇怪的东西。

于 2015-07-06T22:16:55.270 回答
0

我会检查 HTML 输出代码以查看生成的最终选择标记,但我认为您可能需要它,例如 [['Ordered','Ordered'],['Received','Received']]

于 2015-07-06T18:35:31.570 回答