Я не розумію, чому в деяких класах їх ін'єкції залежності оголошуються двічі - один раз у di.xml
конструкторі конкретного класу та в ньому.
Наприклад, у Magento\Backend\Model\Url
, di.xml
визначено цей набір типів для DI:
<type name="Magento\Backend\Model\Url">
<arguments>
<argument name="scopeResolver" xsi:type="object">
Magento\Backend\Model\Url\ScopeResolver</argument>
<argument name="authSession" xsi:type="object">
Magento\Backend\Model\Auth\Session\Proxy</argument>
<argument name="formKey" xsi:type="object">
Magento\Framework\Data\Form\FormKey\Proxy</argument>
<argument name="scopeType" xsi:type="const">
Magento\Store\Model\ScopeInterface::SCOPE_STORE </argument>
<argument name="backendHelper" xsi:type="object">
Magento\Backend\Helper\Data\Proxy</argument>
</arguments>
</type>
Але в той же час у своєму конкретному класі ті класи, які визначені у di.xml, необхідні для введення, знову декларуються у конструкторі:
<?php
public function __construct(
\Magento\Framework\App\Route\ConfigInterface $routeConfig,
\Magento\Framework\App\RequestInterface $request,
\Magento\Framework\Url\SecurityInfoInterface $urlSecurityInfo,
\Magento\Framework\Url\ScopeResolverInterface $scopeResolver,
\Magento\Framework\Session\Generic $session,
\Magento\Framework\Session\SidResolverInterface $sidResolver,
\Magento\Framework\Url\RouteParamsResolverFactory $routeParamsResolverFactory,
\Magento\Framework\Url\QueryParamsResolverInterface $queryParamsResolver,
\Magento\Framework\App\Config\ScopeConfigInterface $scopeConfig,
$scopeType,
\Magento\Backend\Helper\Data $backendHelper,
\Magento\Backend\Model\Menu\Config $menuConfig,
\Magento\Framework\App\CacheInterface $cache,
\Magento\Backend\Model\Auth\Session $authSession,
\Magento\Framework\Encryption\EncryptorInterface $encryptor,
\Magento\Store\Model\StoreFactory $storeFactory,
\Magento\Framework\Data\Form\FormKey $formKey,
array $data = []
) {
//...
}
?>
Якщо ми розглянемо його конструктор вище, \Magento\Framework\App\Route\ConfigInterface $routeConfig
наприклад, це не визначено в di.xml
. Це визначено лише в конструкторі, і Magento все одно буде вводити його routeConfig
в клас для використання, чи не так? Те саме \Magento\Framework\Encryption\EncryptorInterface $encryptor
і для кількох інших.
Тоді, чому виникає потреба у визначенні інших ін'єкцій як di.xml
у конструкторі, так і в конструкторі, коли таких декларацій у конструкторі достатньо, щоб Magento вводив ці залежності в клас для використання?