最後に、ロードされたすべてのxmlレイアウトを印刷し、magento 2レイアウトがどのように機能するかを知ることができます。また、カスタムモジュールレイアウトがロードされているかどうかを確認するのにも役立ちます。アイデアは次のとおりです。
1 /新しいディレクトリを作成しますSample/Dev
。Sample/Dev/registration.php
Magento 2でモジュールディレクトリを宣言するために作成します。
<?php
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'Sample_Dev',
__DIR__
);
2 /作成Sample/Dev/etc/module.xml
:Magento 2にモジュールのセットアップバージョンを知らせる
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="module.xsd">
<module name="Sample_Dev" setup_version="1.0.0" schema_version="1.0.0" release_version="1.0.1">
</module>
</config>
3 /作成しますSample/Dev/etc/frontend/events.xml
。このファイルでは、イベント「layout_generate_blocks_after」をリッスンします
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd">
<event name="layout_generate_blocks_after">
<observer name="thienphucvx_layout_generate_blocks_after" instance="Sample\Dev\Model\Layout" />
</event>
</config>
4 / Sample/Dev/Model/Layout.php
以下のコンテンツで作成
<?php
namespace Sample\Dev\Model;
use Magento\Framework\Event\Observer;
use Magento\Framework\Event\ObserverInterface;
class Layout implements ObserverInterface
{
protected $_logger;
public function __construct ( \Psr\Log\LoggerInterface $logger
) {
$this->_logger = $logger;
}
public function execute(\Magento\Framework\Event\Observer $observer)
{
$xml = $observer->getEvent()->getLayout()->getXmlString();
/*$this->_logger->debug($xml);*//*If you use it, check ouput string xml in var/debug.log*/
$writer = new \Zend\Log\Writer\Stream(BP . '/var/log/layout_block.xml');
$logger = new \Zend\Log\Logger();
$logger->addWriter($writer);
$logger->info($xml);
return $this;
}
}
5 /新しいモジュールをセットアップします。ホームWebサイトのディレクトリ。CMDコマンドラインを入力します。
– php bin / magento module:Sample_Devを有効にします
– php bin / magento setup:upgrade
6 / xmlファイル(たとえば、ホームページ)を表示するページを更新し、でハンドルxmlファイルを確認しますvar/log/layout_block.xml
。