のシーケンスmodule.xml
はに影響を与えapp/etc/config.php
ます。このファイルは実行時に更新されるbin/magento module:enable Vendor_ModuleName
ため、シーケンスを追加または変更した場合は、モジュールを無効にしてから再度有効にすることをお勧めします。module.xml
ここでファイルを更新してキャッシュをクリアするだけでは十分ではありません。開発中にMagentoがシーケンスの変更を確認できるようにするには、完全にdisable
再enable
サイクルする必要があります。
config.php
ファイル内のモジュールのソート順は、Antonのコメントに従って、他のすべての構成ファイルの読み込みに使用されます。
そのコメントのコードの場所は少し古くなっています。これは、シーケンスをソートするためのコードですhttps://github.com/magento/magento2/blob/2.0.2/lib/internal/Magento/Framework/Module/ModuleList/Loader.php#L131
アップデート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>
同じ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>
私たちの興味を引くものはpageLayoutFileSourceBaseSorted
、同じ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
次のソートを行います
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;
}
where moduleList
はMagento\Framework\Module\ModuleList
、上記のローダーを使用する順番に基づいています。