如何管理与父服务的共同依赖关系
编辑本页警告:您正在浏览的文档欧宝体育电话欧宝娱乐app下载地址Symfony 2.7,现已不再维护。
读本页的更新版本用于Sy欧宝娱乐app下载地址mfony 6.2(当前稳定版本)。
如何管理与父服务的共同依赖关系
当您向应用程序添加更多功能时,您很可能开始拥有共享一些相同依赖项的相关类。例如,您可能有多个存储库类需要doctrine.orm.entity_manager
服务和可选的日志记录器
服务:
12 3 4 5 6 7 8 9 10 11 12 13 14 16 17 18 19 20 21
/ / src / AppBundle /仓库/ BaseDoctrineRepository.php名称空间AppBundle\存储库;/ /……摘要类BaseDoctrineRepository{受保护的$objectManager;受保护的$日志记录器;公共函数__construct(ObjectManager$objectManager){$这->objectManager =$objectManager;}公共函数setLogger(LoggerInterface$日志记录器){$这->记录器=$日志记录器;}/ /……}
您的儿童服务课程可能是这样的:
12 3 4 5 6 7 8 9 10 11 12 13 14 16 17 18 19 20 21
/ / src / AppBundle /仓库/ DoctrineUserRepository.php名称空间AppBundle\存储库;使用AppBundle\存储库\BaseDoctrineRepository/ /……类DoctrineUserRepository扩展BaseDoctrineRepository{//…} / /src/AppBundle/存储库/DoctrinePostRepository.php名称空间AppBundle\存储库;使用AppBundle\存储库\BaseDoctrineRepository/ /……类DoctrinePostRepository扩展BaseDoctrineRepository{//…}
就像你使用PHP继承来避免PHP代码中的重复一样,服务容器允许你扩展父服务以避免重复的服务定义:
- YAML
- XML
- PHP
12 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
服务:app.base_doctrine_repository:由于没有配置类,父服务必须是抽象的文摘:真正的参数:(“@doctrine.orm.entity_manager”)电话:-[setLogger,(' @logger '])app.user_repository:类:AppBundle \ Repository \ DoctrineUserRepository#扩展app.base_doctrine_repository服务家长:app.base_doctrine_repositoryapp.post_repository:类:AppBundle \ Repository \ DoctrinePostRepository家长:app.base_doctrine_repository#……
在这种情况下,有一个父
Service意味着父服务的参数和方法调用应该用于子服务。具体来说,EntityManager
将被注入setLogger ()
将被调用,当app.user_repository
被实例化。
谨慎
的范围
,摘要
而且标签
属性是不继承自父服务。
提示
在所显示的示例中,共享相同配置的类也从PHP中的相同父类扩展而来。这完全没有必要。您只需将类似服务定义的公共部分提取到父服务中,而无需在PHP中扩展父类。
重写父依赖关系
有时您可能想要重写仅为一个子服务注入的服务。你可以通过简单地在子类中指定它来覆盖大多数设置:
- YAML
- XML
- PHP
12 3 4 5 6 7 8 9 10 11 12 13 14 16 17 18 19 20 21
服务:#……app.user_repository:类:AppBundle \ Repository \ DoctrineUserRepository家长:app.base_doctrine_repository#覆盖父服务的公共设置公众:假#追加@应用程序。使用rname_checker' argument to the parent#参数列表参数:(“@app.username_checker”)app.post_repository:类:AppBundle \ Repository \ DoctrinePostRepository家长:app.base_doctrine_repository#覆盖第一个参数(使用特殊的index_N键)参数:index_0:“@doctrine.custom_entity_manager”
此工作,包括代码示例,是根据创作共用BY-SA 3.0许可证。