0

我遇到了这个问题:

#Array:0x00007f3e929cc430 的未定义方法“model_name”

{ 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>
4

1 回答 1

2

您试图在数组上调用 model_name model_name 是 ActiveRecord::Relation 的 ActiveRecord 的一种方法。您没有提供调用 pagy_get_vars(collection, vars) 方法的代码,但您需要确保该集合是某种对象类型,该对象类型具有诸如 ActiveRecord::Relation 之类的 model_name 方法,而不是数组。

也许问题从这里开始:

Data.active_only.where(data_location: @location).sort_by(&:id)

sort_by 正在创建一个数组。

你可以使用:

Data.active_only.where(data_location: @location).order(:id)

这样,结果就不是一个数组,而是一个 ActiveRecord::Relation。

于 2021-10-15T07:12:27.023 回答