1

在 Rails 3.2 应用程序中,我有一个咖啡脚本函数,该函数从具有“已选择”数据属性的元素返回 ID 号数组。

#view (pseudo code!)
<table id='elems_container' data-url=<%= my_path(@object%) >
  <tr data-selected = 'true' data-id = '1'></tr>
  <tr data-selected = 'true' data-id = '2'></tr>
  <tr data-selected = 'false' data-id = '3'></tr>
  <tr data-selected = 'true' data-id = '4'></tr>
</table>

#coffeescript
elems = $("tr[data-selected='true']").map(->
  $(this).data "id"
).get()
$.ajax({ url: $('#elems_container').data('url'), dataType: "script", data: { 'selected_ids': elems } })

这将在日志中返回以下内容

Started GET "/my/path?selected_ids%5B%5D=1&selected_ids%5B%5D=2&selected_ids%5B%5D=4

我现在想在控制器中选择这些选定的 id

@collection = Model.where('id = ?', params[:selected_ids])

相反,这将返回所有模型,而不仅仅是参数中列出的模型。

获取 URL 是否正确,或者 params 数组看起来是否不同?我还有什么做错的?

4

1 回答 1

2

如果您对查询字符串进行 URI 解码,您将看到:

selected_ids[]=1&selected_ids[]=2&selected_ids[]=4

当 Rails 看到方括号时[],它将创建一个数组来params[:selected_ids]保存查询字符串中的值,您将['1','2','4']params[:selected_ids].

当您有多个值要检查时,您想要的 SQL 是:

where id in (1,2,4)

ActiveRecord 足够聪明,可以in在您将这样的数组交给它时使用运算符:

where(:some_column => some_array)

所以你应该可以说:

@collection = Model.where(:id => params[:selected_ids])

并在@collection.

于 2013-10-02T03:21:25.723 回答