0

我正在使用 Symfony 4。我有一个获取的对象 $user 与其他实体有关系。我已经设置了所有的 getter,所以我可以从 $user 对象中获取其他信息。

$user = $em->getDoctrine()->getRepository(User::class)->find($id);

$usergroup = $user->getGroup()->getName();

我要做的是创建一个新对象,用于在将 $user 对象传递给模板之前重新打包我需要的信息。

# controller
$repack_user = new \stdClass();
$repack_user->id = $user->getId();

$user_friends = $user->getFrends();

$friends_gf = [];

foreach($user_friends as $friend) {
    $friends_gf[] = $friend->getGirlfriend()->getName();
}

$repack_user->friends_gf = $friends_gf;

return $this->render("home.html.twig", ['user' => $repack_user]);

然后在模板中,我用类似的程序解压它。

# twig template
{{ user.id }}

{% for gf in user.friends_gf %}
    {{ gf }}
{% endfor %}

但是因为我也可以在 twig 中调用实体函数,所以我可以跳过控制器中的所有重新打包并将 $user 对象直接传递到模板中。

# skipped repack in controller
# twig template
{{ user.getID() }}

{% for friend in user.getfriends %}
    {{ friend.getGirlfriend().getName() }}
{% endfor %}

第一种方法有点多余,因为我必须做两次。第二种方式有点难读。那么哪种方法更合理呢?这方面的常见做法是什么?

4

1 回答 1

1

常见的做法肯定是将你的实体图直接交给视图。

为什么你认为你的第二个例子更难阅读?

如果您不希望模板中出现这些链接调用,您可能需要考虑在您的 User 实体中添加另一个 getter。就像是:

public function getNamesOfFriendsGirlfriends() 
{
  $gfNames = [];
  foreach($this->getFriends() as $friend) {
    $gfNames[] = $friend->getGirlfriend()->getName();
  }
  return $gfNames;
}

然后在您的模板中调用它:

{% for gfName in user.namesOfFriendsGirlfriends %}
    {{ gfName }}
{% endfor %}

如果你需要很多这样的助手并且不想破坏你漂亮干净的实体,你可能需要考虑在视图层中使用之前将它们包装在一个装饰器对象中。

于 2018-03-18T21:18:24.873 回答