Symfony 5 中处理自引用多对多关系表单的实践

symfony 5 中处理自引用多对多关系表单的实践

本文深入探讨了在 Symfony 5 应用中构建自引用多对多关系表单的挑战与解决方案。针对 CollectionType 在自引用实体中可能导致的无限循环问题,我们提出了一种通过创建独立子表单类型并结合前端 J*aScript 动态添加表单字段的策略,从而实现高效、无循环的表单管理。

理解自引用多对多关系与表单挑战

在 Symfony 应用开发中,处理自引用(Self-Referencing)实体关系是一个常见场景,例如在一个 Person 实体中定义其家庭成员 myFamily,而家庭成员本身也是 Person 实体。这种关系通常通过多对多(Many-to-Many)关联来实现。

爱克网络企业网站建设系统 No.090730 爱克网络企业网站建设系统 No.090730

系统特点:功能简洁实用。目前互联网上最简洁的企业网站建设系统!原创程序代码。非网络一般下载后修改的代码。更安全。速度快!界面模版分离。原创的分离思路,完全不同于其他方式,不一样的简单感受!搜索引擎优化。做了基础的seo优化。对搜索引擎更友好系统功能关于我们:介绍企业介绍类信息,可自由添加多个介绍栏目!资讯中心:公司或行业资讯类内容展示。可自由添加多个资讯内容!产品展示:支持类别设置,可添加产品图片

爱克网络企业网站建设系统 No.090730 0 查看详情 爱克网络企业网站建设系统 No.090730

考虑以下 Person 实体定义,其中 myFamily 字段通过 ManyToMany 关联指向自身:

<?php

namespace App\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;

/**
 * @ORM\Entity(repositoryClass=PersonRepository::class)
 */
class Person
{
    /**
     * @ORM\Id
     * @ORM\GeneratedValue
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @ORM\Column(type="string", length=50)
     */
    private $name;

    /**
     * @ORM\Column(type="string", length=50)
     */
    private $firstname;

    /**
     * @ORM\Column(type="string", length=255)
     */
    private $birthdayDate;

    /**
     * @ORM\Column(type="string", length=255)
     */
    private $gender;

    /**
     * @ORM\ManyToMany(targetEntity=Person::class)
     * @ORM\JoinTable(name="family",
     *      joinColumns={@ORM\JoinColumn(name="person_id", referencedColumnName="id")},
     *      inverseJoinColumns={@ORM\JoinColumn(name="family_member_id", referencedColumnName="id")}
     * )
     */
    private $myFamily;

    public function __construct()
    {
        $this->myFamily = new ArrayCollection();
    }

    public function getId(): ?int
    {
        return $this->id;
    }

    public function getName(): ?string
    {
        return $this->

以上就是Symfony 5 中处理自引用多对多关系表单的实践的详细内容,更多请关注php中文网其它相关文章!

本文转自网络,如有侵权请联系客服删除。