繁体   English   中英

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

[英]A more efficient way to merge multiple objects together

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

这是我对此的抨击

    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

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

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

假设

楷模

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>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM