Sekwencja w module.xml
ma wpływ na app/etc/config.php
. Ten plik jest aktualizowany po uruchomieniu, bin/magento module:enable Vendor_ModuleName
więc jeśli dodałeś / zmieniłeś sekwencje, sugeruję wyłączenie modułu, a następnie jego ponowne włączenie. Aktualizowanie module.xml
pliku i wyczyszczenie pamięci podręcznej nie wystarczy tutaj, trzeba zrobić pełną disable
ponownego enable
cyklu dostać Magento, aby zobaczyć zmiany sekwencji w trakcie rozwoju.
Kolejność sortowania modułów w config.php
pliku jest następnie wykorzystywana do ładowania wszystkich innych plików konfiguracyjnych zgodnie z komentarzem Antona tutaj.
Lokalizacje kodu w tym komentarzu są nieco nieaktualne. To jest kod do sortowania sekwencji https://github.com/magento/magento2/blob/2.0.2/lib/internal/Magento/Framework/Module/ModuleList/Loader.php#L131
Aktualizacja 2:
app / etc / di.xml
<type name="Magento\Framework\View\Model\Layout\Merge">
<arguments>
<argument name="fileSource" xsi:type="object">Magento\Framework\View\Layout\File\Collector\Aggregated\Proxy</argument>
<argument name="pageLayoutFileSource" xsi:type="object">pageLayoutFileCollectorAggregated</argument>
<argument name="cache" xsi:type="object">Magento\Framework\App\Cache\Type\Layout</argument>
</arguments>
</type>
który odwołuje się do modułu gromadzącego pliki układu strony w tym samym pliku di.xml
<virtualType name="pageLayoutFileCollectorAggregated" type="Magento\Framework\View\Layout\File\Collector\Aggregated">
<arguments>
<argument name="baseFiles" xsi:type="object">pageLayoutFileSourceBaseSorted</argument>
<argument name="themeFiles" xsi:type="object">pageLayoutFileSourceThemeSorted</argument>
<argument name="overrideBaseFiles" xsi:type="object">pageLayoutFileSourceOverrideBaseSorted</argument>
<argument name="overrideThemeFiles" xsi:type="object">pageLayoutFileSourceOverrideThemeSorted</argument>
</arguments>
</virtualType>
ten, który nas interesuje, pageLayoutFileSourceBaseSorted
wciąż znajduje się w tym samym pliku di.xml
<virtualType name="pageLayoutFileSourceBaseSorted" type="Magento\Framework\View\File\Collector\Decorator\ModuleDependency">
<arguments>
<argument name="subject" xsi:type="object">pageLayoutFileSourceBaseFiltered</argument>
</arguments>
</virtualType>
Magento\Framework\View\File\Collector\Decorator\ModuleDependency
wykonuje następujące sortowanie
protected function getModulePriority($moduleName)
{
if ($this->orderedModules === null) {
$this->orderedModules = $this->moduleList->getNames();
}
$result = array_search($moduleName, $this->orderedModules);
// Assume unknown modules have the same priority, distinctive from known modules
if ($result === false) {
return -1;
}
return $result;
}
gdzie moduleList
jest oparty na tym, Magento\Framework\Module\ModuleList
który z kolei używa modułu ładującego wspomnianego powyżej.