将多个对象合并在一起的更有效方法

时间:2014-11-22 08:24:01

标签: ruby-on-rails ruby

所以我试图创建一个包含多个对象的数组,但首先我需要将两种对象合并为一种,然后将其添加到数组中。这样做的原因是我可以在视图中循环遍历数组并轻松显示内容。我正在使用树不同的对象,用户,玩家和团队。用户通过玩家拥有多个玩家和多个团队。我需要直观地显示团队对象和播放器对象的信息,但我需要将它们合并到一个对象中并将其插入到数组中。因此,我将为玩家拥有的每个团队/玩家执行此操作,并将其插入一个包含所有团队/玩家的阵列。

这是我对此的抨击

    array = []
    @user.players.each do |player|
        @user.teams.each do |team|
            if player.team_id == team.id
                array << UserTeam.new(:id => team.id,
                                      :name => team.name,
                                      :tag => team.tag,
                                      :description => team.description,
                                      :recruiting => team.recruiting,
                                      :wins => team.wins,
                                      :losses => team.losses,
                                      :t_wins => team.t_wins,
                                      :rating => team.rating,
                                      :role => player.role,
                                      :position => player.position)
            end
        end
    end
    @teams = array

这很有效,我得到了我想要的结果,但我确信这是一种非常低效的方法。这会是一个更好的方法吗?任何人都可以帮助新手铁路开出去吗?

1 个答案:

答案 0 :(得分:3)

很难确定为什么你实际上把所有东西都集中在一个对象中。你打算怎么做结果?如果这仅用于显示目的,您可以使用更简单,更优雅的东西。

假设

模型

class User < ActiveRecord::Base
  has_many :players
  has_many :teams, through: :players
end

class Player < ActiveRecord::Base
  belongs_to :user
  belongs_to :team
end

class Team < ActiveRecord::Base
  has_many :players
end

控制器

@players = @user.players.includes(:team)

视图

<table>
  <thead>
    <tr>
      <th>Team Id</th>
      <th>Team Name</th>
      <!-- other team columns -->
      <th>Player Role</th>
      <th>Player Position</th>
    </tr>
  </thead>
  <tbody>
  <% @players.each do |player| %>
    <tr>
      <td><%= player.team.id %></td>
      <td><%= player.team.name %></td>
      <!-- other columns -->
      <td><%= player.role %></td>
      <td><%= player.position %></td>
    </tr>
  <% end %>
  </tbody>
</table>