返回数组中的下一个对象



我希望此代码输出当前维度成员和下一个维度成员的名称,其中next由每个维度成员的absorder属性定义。

<% @dimension_members.each do |dm| %>
    <p><%= dm.name %></p>
    <p><%= DimensionMember.where(:absorder => dm.absorder+1).name %></p>
<% end %>

相反,代码返回当前维度成员的名称,然后为每个下一个成员返回"DimensionMember"。

以下代码生成#<ActiveRecord::Relation:0x3f952e0>:

<% @dimension_members.each do |dm| %>
    <p><%= dm.name %></p>
    <p><%= DimensionMember.where(:absorder => dm.absorder+1) %></p>
<% end %>

我不得不想象有一种更简单的方法来返回数组中的下一个成员,但我无法完全实现。考虑到这个想法,我尝试了以下代码,但它产生了#<DimensionMember:0x3f943f8>:

<% @dimension_members.each do |dm| %>
    <p><%= dm.name %></p>
    <p><%= @dimension_members[dm.absorder+1] %></p>
<% end %>

最后,我试过这个:

<% @dimension_members.each do |dm| %>
    <p><%= dm.name %></p>
    <p><%= @dimension_members[dm.absorder+1].name %></p>
<% end %>

但这会返回错误:

undefined method 'name' for nil:NilClass

那么,我如何获得nextdimension_member,其中next是由特定属性absorder定义的呢?

得到奇怪结果的原因是where查询返回的是关系/集合,而不是单个对象。您只需要使用从查询中获取第一个对象

DimensionMember.where(:absorder => dm.absorder+1).first.try(:name)

<% @dimension_members.each do |dm| %>
    <p><%= dm.name %></p>
    <p><%= DimensionMember.where(:absorder => dm.absorder+1).first.try(:name) %></p>
<% end %>

您可以使用next:访问数组的下一个元素

<% @dimension_members.each_with_index do |dm, index| %>
    <p><%= dm.name %></p>
    <p><%= @dimension_members[index + 1].name %></p>
<% end %>

这就是你想要的,还是@dimension_members还没有按照这个"absorder"属性排序?如果没有,也许您应该在迭代之前对其进行排序。

相关内容

  • 没有找到相关文章

最新更新