我目前有3张表goods
、category
and brand
,在sonata后台中,我希望可以把类别名称和品牌名称全部显示在货品列表,下图有详细的信息:
从上图可以看出,iphone6plus的类别是mobile,这里我在yml文件中定义了many-to-one的关系,这里显示是正确的,但是brand.name很明显错了,iphone6plus的品牌应该是apple,这里我有疑问,我我在 goods.yml 文件中定义了两次many-to-one关系,第二次定义的是goods
与brand
表,并没有正确显示。
我想更便捷地管理货品信息,在同一页面,浏览商品类别和品牌,在编辑页面同理,我应该如何实现呢?下面是我的代码块:
brand.orm.yml
Application\Sonata\MallBundle\Entity\Brand:
type: entity
table: brand
...
oneToMany:
goods:
targetEntity: Goods
mappedBy: brand
lifecycleCallbacks: { }
goods.orm.yml
Application\Sonata\MallBundle\Entity\Goods:
type: entity
table: goods
repositoryClass: Application\Sonata\MallBundle\Repository\GoodsRepository
...
manyToOne:
category:
targetEntity: Category
inverseBy: goods
joinColumn:
name: category_id
referencedColumnName: id
manyToOne:
brand:
targetEntity: Brand
inverseBy: goods
joinColumn:
name: brand_id
referencedColumnName: id
lifecycleCallbacks: { }
category.orm.yml
Application\Sonata\MallBundle\Entity\Category:
type: entity
table: category
repositoryClass: Application\Sonata\MallBundle\Repository\CategoryRepository
...
oneToMany:
goods:
targetEntity: Goods
mappedBy: category
lifecycleCallbacks: { }
您的建议,对我来说是莫大的帮助。
方案:
你需要把
关注点
放在GoodsAdmin
(通常位于AppBundle\Admin
命名空间下)这个类中。实现你想要的结果,你需要针对这个类,做如下修改(
注意中文注释
)。要点:
第一个方法中,通过
小数点
(dot notation
)的形式访问关联实体
(associated entity
)的属性 (property
),用来在表格中显示。第二个方法中,通过使用
SonataAdminBundle
的sonata_type_model
表单类型(form type
),在当前表单中生成关联实体
的选择控件,同时还可以直接在当前表单中新建(通过Ajax
)。如果熟悉
Symfony Form
组件的用法,该类中的各个方法的配置用起来就会比较自然。建议看下前者的用法。总结:
SonataAdminBundle
官方文档质量一般,更新缓慢,对开发者容易造成阻碍,但是,建议还是仔细啃一下官方文档,然后开发起来就容易多了。文档链接:ADMIN BUNDLE