使用 pagy gem 时 #Array 的未定义方法 `model_name'
undefined method `model_name' for #Array when using pagy gem
我遇到了这个问题:
undefined method `model_name' for #Array:0x00007f3e929cc430
{ count: collection.count(:all),
page: params[vars[:page_param]||Pagy::VARS[:page_param]],
item_path: "activerecord.models.#{collection.model_name.i18n_key}" }.merge!(vars)
end
这是我的 data_controller.rb:
def index
@pagy, @datas = pagy(Data.active_only.where(data_location: @location).sort_by(&:id))
end
这是我的 application_controller.rb
def pagy_get_vars(collection, vars)
{ count: collection.count(:all),
page: params[vars[:page_param]||Pagy::VARS[:page_param]],
item_path: "activerecord.models.#{collection.model_name.i18n_key}" }.merge!(vars)
end
最后是我的观点
<div>
<table id="tablestock" class="table_content table">
<thead>
<tr>
<th>ID</th>
<th>Date</th>
<th class="sorting_disabled">Location</th>
<th class="sorting_disabled">Name</th>
</tr>
</thead>
<tbody>
<% @datas.each do |data| %>
<tr data-link="<%= data_path(data) %>">
<td><%= data.id %></td>
<td><%= data.created_at.strftime('%d %b %Y') rescue ("<b style='color:red; font-size:16px;'>ERROR</b>".html_safe)%></td>
<td><%=data.data_location.location if data.location_id? %></td>
<td><%= data.data_name.name if data.name_id? %></td>
</tr>
<% end %>
</tbody>
</table>
<div class="justify">
<%= pagy_nav(@pagy).html_safe if @datas.present? %>
</div>
</div>
您正试图在数组 model_name 上调用 model_name 是 ActiveRecord::Relation 的 ActiveRecord 的一个方法。您没有提供调用 pagy_get_vars(collection, vars) 方法的代码,但您需要确保该集合是具有 model_name 方法(如 ActiveRecord::Relation 和不是数组。
也许问题是从这里开始的:
Data.active_only.where(data_location: @location).sort_by(&:id)
sort_by 正在创建数组。
您可以使用:
Data.active_only.where(data_location: @location).order(:id)
这样,结果不是数组而是 ActiveRecord::Relation。
我遇到了这个问题:
undefined method `model_name' for #Array:0x00007f3e929cc430
{ count: collection.count(:all),
page: params[vars[:page_param]||Pagy::VARS[:page_param]],
item_path: "activerecord.models.#{collection.model_name.i18n_key}" }.merge!(vars)
end
这是我的 data_controller.rb:
def index
@pagy, @datas = pagy(Data.active_only.where(data_location: @location).sort_by(&:id))
end
这是我的 application_controller.rb
def pagy_get_vars(collection, vars)
{ count: collection.count(:all),
page: params[vars[:page_param]||Pagy::VARS[:page_param]],
item_path: "activerecord.models.#{collection.model_name.i18n_key}" }.merge!(vars)
end
最后是我的观点
<div>
<table id="tablestock" class="table_content table">
<thead>
<tr>
<th>ID</th>
<th>Date</th>
<th class="sorting_disabled">Location</th>
<th class="sorting_disabled">Name</th>
</tr>
</thead>
<tbody>
<% @datas.each do |data| %>
<tr data-link="<%= data_path(data) %>">
<td><%= data.id %></td>
<td><%= data.created_at.strftime('%d %b %Y') rescue ("<b style='color:red; font-size:16px;'>ERROR</b>".html_safe)%></td>
<td><%=data.data_location.location if data.location_id? %></td>
<td><%= data.data_name.name if data.name_id? %></td>
</tr>
<% end %>
</tbody>
</table>
<div class="justify">
<%= pagy_nav(@pagy).html_safe if @datas.present? %>
</div>
</div>
您正试图在数组 model_name 上调用 model_name 是 ActiveRecord::Relation 的 ActiveRecord 的一个方法。您没有提供调用 pagy_get_vars(collection, vars) 方法的代码,但您需要确保该集合是具有 model_name 方法(如 ActiveRecord::Relation 和不是数组。
也许问题是从这里开始的:
Data.active_only.where(data_location: @location).sort_by(&:id)
sort_by 正在创建数组。
您可以使用:
Data.active_only.where(data_location: @location).order(:id)
这样,结果不是数组而是 ActiveRecord::Relation。