文章列表


magento2中的缓存私有内容以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在 Magento 2 中,可以使用 Cache Manager 来创建和管理缓存。Cache Manager 可以帮助您在代码中缓存任何数据,包括私有内容。</p><p><br/></p><p>以下是一个示例,演示如何使用 Cache Manager 缓存私有内容:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?php namespace&nbsp;Namespace\Module\Block; use&nbsp;Magento\Framework\View\Element\Template\Context; use&nbsp;Magento\Framework\App\Cache\TypeListInterface; use&nbsp;Magento\Framework\App\Cache\Frontend\Pool; use&nbsp;Magento\Framework\App\Cache\StateInterface; class&nbsp;CustomBlock&nbsp;extends&nbsp;\Magento\Framework\View\Element\Template { &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;$_cacheManager; &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;__construct( &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Context&nbsp;$context, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;TypeListInterface&nbsp;$cacheTypeList, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Pool&nbsp;$cacheFrontendPool, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;StateInterface&nbsp;$cacheState, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;array&nbsp;$data&nbsp;=&nbsp;[] &nbsp;&nbsp;&nbsp;&nbsp;)&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_cacheManager&nbsp;=&nbsp;$context-&gt;getCacheManager(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct($context,&nbsp;$data); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;function&nbsp;_toHtml() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$cacheKey&nbsp;=&nbsp;&#39;my_custom_block&#39;; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$cacheTag&nbsp;=&nbsp;[&#39;my_custom_block_tag&#39;]; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;($this-&gt;_cacheManager-&gt;load($cacheKey))&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;$this-&gt;_cacheManager-&gt;load($cacheKey); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$result&nbsp;=&nbsp;&#39;My&nbsp;Custom&nbsp;Block&nbsp;Content&#39;; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_cacheManager-&gt;save($result,&nbsp;$cacheKey,&nbsp;$cacheTag); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;$result; &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在上面的示例中,我们使用 _cacheManager 对象来缓存自定义块的私有内容。我们首先尝试从缓存中获取内容,如果找到了缓存,就直接返回缓存内容。否则,我们创建我们的内容,并将其保存到缓存中以备下次使用。</p><p><br/></p><p>我们使用 load() 方法从缓存中加载内容,该方法接受一个缓存键作为参数。如果找到了缓存,它会返回缓存内容,否则返回 false。</p><p><br/></p><p>我们使用 save() 方法将内容保存到缓存中。该方法接受三个参数:缓存内容、缓存键和缓存标签。缓存标签可以用于标记缓存,以便在需要清除缓存时进行识别。</p><p><br/></p><p>缓存管理器还提供其他方法,例如 remove() 和 clean(),用于清除缓存。</p><p><br/></p>

magento2中的缓存公共内容以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>Magento 2 中的缓存分为多种类型,其中包括缓存页面、布局、块、对象、集合和配置等。下面是一些常见的缓存类型和代码示例:</p><p>缓存页面</p><p>缓存页面是 Magento 2 中的一种缓存类型,它将整个页面缓存起来,以便下次访问时可以直接从缓存中读取。要使用 Magento 2 的页面缓存,您可以在布局文件中使用 <span style="color: #569cd6;">cacheable</span>=<span style="color: #ce9178;">&quot;true&quot;</span> 标记。</p><pre class="brush:as3;toolbar:false">&lt;page&nbsp;xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot;&nbsp;xsi:noNamespaceSchemaLocation=&quot;urn:magento:framework:View/Layout/etc/page_configuration.xsd&quot;&nbsp;layout=&quot;2columns-left&quot;&nbsp;cacheable=&quot;true&quot;&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;!--&nbsp;页面内容&nbsp;--&gt; &lt;/page&gt;</pre><p>缓存块</p><p>缓存块是 Magento 2 中的另一种缓存类型,它可以将单个块的内容缓存起来,以便下次访问时可以直接从缓存中读取。要使用 Magento 2 的块缓存,您可以在块的 PHP 类中使用 <span style="color: #569cd6;">cacheable</span>=<span style="color: #ce9178;">&quot;true&quot;</span> 标记。</p><p><br/></p><p>例如,下面是一个使用块缓存的 PHP 类示例:</p><p><br/></p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?php namespace&nbsp;Vendor\Module\Block; use&nbsp;Magento\Framework\View\Element\Template; class&nbsp;MyBlock&nbsp;extends&nbsp;Template { &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@var&nbsp;bool &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;$_isScopePrivate&nbsp;=&nbsp;true; &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@return&nbsp;bool &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;function&nbsp;_isAllowed() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;$this-&gt;_authorization-&gt;isAllowed(&#39;Vendor_Module::my_resource&#39;); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@return&nbsp;string &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;getCacheKeyInfo() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;[ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#39;VENDOR_MODULE_MYBLOCK&#39;, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_storeManager-&gt;getStore()-&gt;getId(), &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_design-&gt;getDesignTheme()-&gt;getId(), &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_customerSession-&gt;getCustomerGroupId(), &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;intval($this-&gt;_customerSession-&gt;isLoggedIn()), &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;getRequest()-&gt;getParam(&#39;id&#39;), &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_scopeConfig-&gt;getValue(&#39;vendor/module/feature_enabled&#39;) &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;]; &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在上面的示例中,我们可以看到 MyBlock 类继承自 Template 类,并实现了 getCacheKeyInfo() 方法和 _isScopePrivate 属性,这使得块的内容可以被缓存起来。</p><p><br/></p>

magento2中的创建缓存类型以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在 Magento 2 中,可以通过创建自定义的缓存类型来缓存您的应用程序数据。下面是一个示例,演示如何在 Magento 2 中创建自定义缓存类型:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?php namespace&nbsp;Namespace\Module\Model\Cache\Type; use&nbsp;Magento\Framework\App\Cache\Type\FrontendPool; use&nbsp;Magento\Framework\Cache\Frontend\Decorator\TagScope; class&nbsp;CustomCacheType&nbsp;extends&nbsp;TagScope { &nbsp;&nbsp;&nbsp;&nbsp;const&nbsp;CACHE_TYPE&nbsp;=&nbsp;&#39;custom_cache_type&#39;; &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;__construct(FrontendPool&nbsp;$cacheFrontendPool) &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct($cacheFrontendPool-&gt;get(self::CACHE_TYPE),&nbsp;self::CACHE_TYPE); &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在上面的示例中,我们创建了一个名为 CustomCacheType 的自定义缓存类型,并继承了 TagScope 类来支持标签。</p><p><br/></p><p>我们定义了 CACHE_TYPE 常量来表示缓存类型的名称。</p><p><br/></p><p>我们在 __construct() 方法中获取缓存实例,并将其传递给 TagScope 类的构造函数。</p><p><br/></p><p>接下来,我们需要在 di.xml 文件中注册缓存类型:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;config&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;type&nbsp;name=&quot;Namespace\Module\Model\Cache\Type\CustomCacheType&quot;&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;arguments&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;argument&nbsp;name=&quot;cacheFrontendPool&quot;&nbsp;xsi:type=&quot;object&quot;&gt;Magento\Framework\App\Cache\Type\FrontendPool&lt;/argument&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;/arguments&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;/type&gt; &lt;/config&gt;</pre><p>在上面的示例中,我们将 Namespace\Module\Model\Cache\Type\CustomCacheType 类型注册为缓存类型,并传递了 cacheFrontendPool 依赖项。</p><p><br/></p><p>现在,我们可以在代码中使用我们的自定义缓存类型。例如,以下是一个示例,演示如何在 Magento 2 中使用自定义缓存类型:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?php namespace&nbsp;Namespace\Module\Block; use&nbsp;Namespace\Module\Model\Cache\Type\CustomCacheType; class&nbsp;CustomBlock&nbsp;extends&nbsp;\Magento\Framework\View\Element\Template { &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;$cacheType; &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;__construct( &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;\Magento\Framework\View\Element\Template\Context&nbsp;$context, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CustomCacheType&nbsp;$cacheType, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;array&nbsp;$data&nbsp;=&nbsp;[] &nbsp;&nbsp;&nbsp;&nbsp;)&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct($context,&nbsp;$data); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;cacheType&nbsp;=&nbsp;$cacheType; &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;function&nbsp;_toHtml() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$cacheKey&nbsp;=&nbsp;&#39;my_cache_key&#39;; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$cacheData&nbsp;=&nbsp;$this-&gt;cacheType-&gt;load($cacheKey); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(!$cacheData)&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$cacheData&nbsp;=&nbsp;&#39;My&nbsp;cached&nbsp;data&#39;; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;cacheType-&gt;save($cacheData,&nbsp;$cacheKey,&nbsp;[],&nbsp;86400);&nbsp;//&nbsp;缓存时间为一天 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;$cacheData; &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在上面的示例中,我们在 __construct() 方法中注入了我们的自定义缓存类型 CustomCacheType。在 _toHtml() 方法中,我们使用 load() 方法来从缓存中获取数据,并使用 save() 方法将数据保存到缓存中。</p><p><br/></p><p>当缓存启用时,Magento 2 会在页面加载时自动缓存块。Magento 2 会检查缓存是否存在并且没有过期,如果找到了缓存,则直接从缓存中获取内容,否则会生成新的内容并将其保存到缓存中以备下次使用</p><p><br/></p>

magento2中的创建自定义缓存引擎以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在 Magento 2 中,我们可以自定义缓存引擎来实现自己的缓存逻辑。这对于一些特殊场景下的缓存需求非常有用,例如需要使用自定义的缓存存储介质,或需要在缓存中存储一些特殊类型的数据。</p><p>以下是创建自定义缓存引擎的一般步骤:</p><ol style="border: 0px solid rgb(217, 217, 227); box-sizing: border-box; --tw-border-spacing-x:0; --tw-border-spacing-y:0; --tw-translate-x:0; --tw-translate-y:0; --tw-rotate:0; --tw-skew-x:0; --tw-skew-y:0; --tw-scale-x:1; --tw-scale-y:1; --tw-pan-x: ; --tw-pan-y: ; --tw-pinch-zoom: ; --tw-scroll-snap-strictness:proximity; --tw-ordinal: ; --tw-slashed-zero: ; --tw-numeric-figure: ; --tw-numeric-spacing: ; --tw-numeric-fraction: ; --tw-ring-inset: ; --tw-ring-offset-width:0px; --tw-ring-offset-color:#fff; --tw-ring-color:rgba(59,130,246,0.5); --tw-ring-offset-shadow:0 0 transparent; --tw-ring-shadow:0 0 transparent; --tw-shadow:0 0 transparent; --tw-shadow-colored:0 0 transparent; --tw-blur: ; --tw-brightness: ; --tw-contrast: ; --tw-grayscale: ; --tw-hue-rotate: ; --tw-invert: ; --tw-saturate: ; --tw-sepia: ; --tw-drop-shadow: ; --tw-backdrop-blur: ; --tw-backdrop-brightness: ; --tw-backdrop-contrast: ; --tw-backdrop-grayscale: ; --tw-backdrop-hue-rotate: ; --tw-backdrop-invert: ; --tw-backdrop-opacity: ; --tw-backdrop-saturate: ; --tw-backdrop-sepia: ; list-style-position: initial; list-style-image: initial; margin-top: 1.25em; margin-bottom: 1.25em; padding: 0px 0px 0px 1rem; counter-reset: item 0; display: flex; flex-direction: column; color: rgb(55, 65, 81); font-family: Söhne, ui-sans-serif, system-ui, -apple-system, &quot;Segoe UI&quot;, Roboto, Ubuntu, Cantarell, &quot;Noto Sans&quot;, sans-serif, &quot;Helvetica Neue&quot;, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Noto Color Emoji&quot;; white-space: pre-wrap; background-color: rgb(247, 247, 248);" class=" list-paddingleft-2"><li><p>创建自定义缓存引擎的 PHP 类,该类必须实现 Magento\Framework\Cache\FrontendInterface 接口。</p></li></ol><pre>namespace&nbsp;Vendor\Module\Cache; use&nbsp;Magento\Framework\App\Cache\Type\FrontendPoolInterface; use&nbsp;Magento\Framework\Cache\Frontend\Decorator\TagScope; class&nbsp;MyCustomCache&nbsp;extends&nbsp;TagScope { &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;__construct( &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;FrontendPoolInterface&nbsp;$cacheFrontendPool, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$options&nbsp;=&nbsp;[] &nbsp;&nbsp;&nbsp;&nbsp;)&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;parent::__construct($cacheFrontendPool-&gt;get(&#39;my_custom_cache&#39;),&nbsp;$options); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@inheritDoc &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;load($id) &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;TODO:&nbsp;实现缓存加载逻辑 &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@inheritDoc &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;save($data,&nbsp;$id,&nbsp;$tags&nbsp;=&nbsp;[],&nbsp;$lifeTime&nbsp;=&nbsp;null) &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;TODO:&nbsp;实现缓存保存逻辑 &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@inheritDoc &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;remove($id) &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;TODO:&nbsp;实现缓存删除逻辑 &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;/** &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*&nbsp;@inheritDoc &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;clean($mode&nbsp;=&nbsp;\Zend_Cache::CLEANING_MODE_ALL,&nbsp;$tags&nbsp;=&nbsp;[]) &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;TODO:&nbsp;实现缓存清除逻辑 &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在上述代码中,我们创建了一个名为 MyCustomCache 的自定义缓存引擎类,它继承自 TagScope 类,并实现了 load()、save()、remove() 和 clean() 方法。其中,load() 方法用于加载缓存数据,save() 方法用于保存缓存数据,remove() 方法用于删除缓存数据,clean() 方法用于清除缓存数据。我们需要根据实际需求来实现这些方法的逻辑。</p><p>在 Magento 2 中注册自定义缓存引擎:</p><pre>&lt;cache&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;types&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;custom_cache&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;label&gt;My&nbsp;Custom&nbsp;Cache&lt;/label&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;frontend_class&gt;Vendor\Module\Cache\MyCustomCache&lt;/frontend_class&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;backend_class&gt;Magento\Cache\Backend\File&lt;/backend_class&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;frontend_options&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;backend&gt;Magento\Cache\Backend\File&lt;/backend&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;/frontend_options&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;/custom_cache&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;/types&gt; &lt;/cache&gt;</pre><p>在上述代码中,我们使用 XML 配置文件注册了一个名为 custom_cache 的自定义缓存类型,并指定了我们刚才创建的 MyCustomCache 类作为前端缓存类。我们还指定了一个名为 Magento\Cache\Backend\File 的后端缓存类,它将缓存数据保存在文件中。这是可选的,您可以根据实际需求指定不同的后端缓存类。</p>

magento2中的测试你的组件以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>Magento 2 是一个基于 PHP 的开源电子商务平台,可以使用 PHPUnit 和 Magento 提供的测试框架进行单元测试、集成测试和功能测试。在 Magento 2 中,测试是非常重要的,因为它可以帮助开发人员提高代码质量、减少错误和缺陷,并确保所有模块和扩展都能够良好地协作。</p><p><br/></p><p>下面是 Magento 2 中进行单元测试、集成测试和功能测试的代码示例:</p><p><br/></p><p>单元测试示例</p><p>假设我们有一个 Calculator 类,它有两个方法 add 和 subtract,分别用于加法和减法运算。下面是一个对 Calculator 类进行单元测试的示例:</p><p><br/></p><pre class="brush:as3;toolbar:false">use&nbsp;PHPUnit\Framework\TestCase; class&nbsp;CalculatorTest&nbsp;extends&nbsp;TestCase { &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;testAdd() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$calculator&nbsp;=&nbsp;new&nbsp;Calculator(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$result&nbsp;=&nbsp;$calculator-&gt;add(2,&nbsp;3); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;assertEquals(5,&nbsp;$result); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;testSubtract() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$calculator&nbsp;=&nbsp;new&nbsp;Calculator(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$result&nbsp;=&nbsp;$calculator-&gt;subtract(5,&nbsp;2); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;assertEquals(3,&nbsp;$result); &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在这个示例中,我们使用 PHPUnit 的 TestCase 类来编写测试用例。在每个测试方法中,我们创建一个 Calculator 对象并调用相应的方法进行测试。然后使用 assertEquals 方法来验证结果是否正确。</p><p><br/></p><p>集成测试示例</p><p>假设我们有一个 Customer 类,它包含一些方法用于与数据库进行交互,例如 getById 和 save。下面是一个对 Customer 类进行集成测试的示例:</p><p><br/></p><pre class="brush:as3;toolbar:false">use&nbsp;Magento\TestFramework\TestCase\AbstractController; class&nbsp;CustomerTest&nbsp;extends&nbsp;AbstractController { &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;testGetById() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customerId&nbsp;=&nbsp;1; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customer&nbsp;=&nbsp;$this-&gt;_objectManager-&gt;create(&#39;Magento\Customer\Model\Customer&#39;); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customer-&gt;load($customerId); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;assertEquals(&#39;John&#39;,&nbsp;$customer-&gt;getFirstName()); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;assertEquals(&#39;Doe&#39;,&nbsp;$customer-&gt;getLastName()); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;testSave() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customerData&nbsp;=&nbsp;[ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#39;firstname&#39;&nbsp;=&gt;&nbsp;&#39;Jane&#39;, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#39;lastname&#39;&nbsp;=&gt;&nbsp;&#39;Doe&#39;, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#39;email&#39;&nbsp;=&gt;&nbsp;&#39;jane@example.com&#39;, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;]; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customer&nbsp;=&nbsp;$this-&gt;_objectManager-&gt;create(&#39;Magento\Customer\Model\Customer&#39;); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customer-&gt;setData($customerData); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$customer-&gt;save(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;assertNotEmpty($customer-&gt;getId()); &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在这个示例中,我们使用 Magento 提供的 AbstractController 类来编写集成测试用例。在每个测试方法中,我们使用 Magento 对象管理器创建一个 Customer 对象,并调用相应的方法进行测试。然后使用 assertEquals 和 assertNotEmpty 方法来验证结果是否正确。</p><p><br/></p>

magento2中的分发组件以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>Magento 2 中的分发组件是整个系统的核心,它实现了应用程序的启动、请求路由、处理以及响应输出等核心功能。以下是 Magento 2 中分发组件的代码示例和说明:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?php use&nbsp;Magento\Framework\App\Request\Http&nbsp;as&nbsp;HttpRequest; use&nbsp;Magento\Framework\App\Bootstrap; require&nbsp;__DIR__&nbsp;.&nbsp;&#39;/app/bootstrap.php&#39;; $bootstrap&nbsp;=&nbsp;Bootstrap::create(BP,&nbsp;$_SERVER); /**&nbsp;@var&nbsp;HttpRequest&nbsp;$request&nbsp;*/ $request&nbsp;=&nbsp;$bootstrap-&gt;getObjectManager()-&gt;get(HttpRequest::class); $request-&gt;setRequestUri(&#39;/hello/world&#39;)-&gt;setMethod(&#39;GET&#39;); try&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;$objectManager&nbsp;=&nbsp;$bootstrap-&gt;getObjectManager(); &nbsp;&nbsp;&nbsp;&nbsp;/**&nbsp;@var&nbsp;\Magento\Framework\App\Http&nbsp;$app&nbsp;*/ &nbsp;&nbsp;&nbsp;&nbsp;$app&nbsp;=&nbsp;$objectManager-&gt;get(&#39;Magento\Framework\App\Http&#39;); &nbsp;&nbsp;&nbsp;&nbsp;$app-&gt;bootstrap(); &nbsp;&nbsp;&nbsp;&nbsp;$response&nbsp;=&nbsp;$app-&gt;getFrontController()-&gt;dispatch($request); &nbsp;&nbsp;&nbsp;&nbsp;echo&nbsp;$response-&gt;getBody(); }&nbsp;catch&nbsp;(\Exception&nbsp;$e)&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;echo&nbsp;$e-&gt;getMessage(); }</pre><p>以上代码中,我们创建了一个 HTTP 请求对象 $request,设置了请求的 URI 和方法。通过 $objectManager-&gt;get(<span style="color: #ce9178;">&#39;Magento\Framework\App\Http&#39;</span>) 获取到 Magento 2 的应用程序对象,然后通过 $app-&gt;getFrontController()-&gt;dispatch($request) 分发请求。最后输出响应内容。</p><p><br/></p><p>需要注意的是,上述示例仅适用于测试目的,实际应用中应该使用正确的 URI 和请求方法。另外,$bootstrap-&gt;create() 方法还可以接受一个可选的参数 $params,可以在应用程序启动时传递额外的参数,例如:$bootstrap-&gt;create(BP, $_SERVER, [<span style="color: #ce9178;">&#39;entryPoint&#39;</span> =&gt; <span style="color: #ce9178;">&#39;index.php&#39;</span>])<span style="color: #6a9955;">;。</span></p><p><br/></p><p>在 Magento 2 中,分发组件还可以通过 di.xml 文件中的 front_controller_listeners 配置节点来添加事件监听器,从而在分发请求前或分发请求后执行额外的逻辑。例如,下面的示例展示了如何添加一个前置事件监听器:</p><p><br/></p><p>在 app/code/Vendor/Module/etc/frontend/di.xml 文件中添加以下内容:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;config&nbsp;xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot;&nbsp;xsi:noNamespaceSchemaLocation=&quot;urn:magento:framework:ObjectManager/etc/config.xsd&quot;&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;type&nbsp;name=&quot;Magento\Framework\App\FrontControllerInterface&quot;&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;plugin&nbsp;name=&quot;Vendor_Module::beforeDispatch&quot;&nbsp;type=&quot;Vendor\Module\Plugin\FrontControllerPlugin&quot;&nbsp;sortOrder=&quot;10&quot;&nbsp;/&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;/type&gt; &lt;/config&gt;</pre><p>然后在 app/code/Vendor/Module/Plugin/FrontControllerPlugin.php 文件中添加以下内容:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?php namespace&nbsp;Vendor\Module\Plugin; use&nbsp;Magento\Framework\App\RequestInterface; use&nbsp;Magento\Framework\App\ResponseInterface; class&nbsp;FrontControllerPlugin { &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;beforeDispatch($subject,&nbsp;RequestInterface&nbsp;$request) &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;Do&nbsp;something&nbsp;before&nbsp;dispatching&nbsp;the&nbsp;request &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>以上代码中,我们创建了一个名为 beforeDispatch 的前置事件监听器,并在监听器类中实现了 beforeDispatch 方法,在此方法中可以添加一些在分发请求前需要执行的逻辑。</p><p><br/></p><p>总结一下,分发组件是 Magento 2 应用程序的核心组件之一,它负责启动应用程序、处理请求并返回响应。</p><p><br/></p>

magento2中的启用或禁用组件以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在 Magento 2 中,可以通过在 app/etc/config.php 文件中启用或禁用组件。</p><p><br/></p><p>要启用组件,请将组件名称添加到 config.php 文件的 modules 数组中。例如,要启用名为 My_Module 的组件,请将其名称添加到 modules 数组中:</p><pre class="brush:as3;toolbar:false"> &#39;modules&#39;&nbsp;=&gt;&nbsp;[ &nbsp;&nbsp;&nbsp;&nbsp;&#39;Magento_Store&#39;&nbsp;=&gt;&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;&#39;Magento_Directory&#39;&nbsp;=&gt;&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;&#39;Magento_Eav&#39;&nbsp;=&gt;&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;... &nbsp;&nbsp;&nbsp;&nbsp;&#39;My_Module&#39;&nbsp;=&gt;&nbsp;1 ],</pre><p>要禁用组件,请将其名称添加到 modules 数组中,并将其值设置为 0。例如,要禁用名为 My_Module 的组件,请将其名称添加到 modules 数组中,并将其值设置为 0:</p><p><br/></p><pre class="brush:as3;toolbar:false">&#39;modules&#39;&nbsp;=&gt;&nbsp;[ &nbsp;&nbsp;&nbsp;&nbsp;&#39;Magento_Store&#39;&nbsp;=&gt;&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;&#39;Magento_Directory&#39;&nbsp;=&gt;&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;&#39;Magento_Eav&#39;&nbsp;=&gt;&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;... &nbsp;&nbsp;&nbsp;&nbsp;&#39;My_Module&#39;&nbsp;=&gt;&nbsp;0 ],</pre><p>注意:禁用组件时,不会加载该组件的代码和配置文件。</p><p><br/></p>

magento2中的组件加载顺序以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在 Magento 2 中,组件的加载顺序非常重要,因为它们的功能可能会相互依赖。下面是 Magento 2 中组件加载的顺序:</p><ol style="border: 0px solid rgb(217, 217, 227); box-sizing: border-box; --tw-border-spacing-x:0; --tw-border-spacing-y:0; --tw-translate-x:0; --tw-translate-y:0; --tw-rotate:0; --tw-skew-x:0; --tw-skew-y:0; --tw-scale-x:1; --tw-scale-y:1; --tw-pan-x: ; --tw-pan-y: ; --tw-pinch-zoom: ; --tw-scroll-snap-strictness:proximity; --tw-ordinal: ; --tw-slashed-zero: ; --tw-numeric-figure: ; --tw-numeric-spacing: ; --tw-numeric-fraction: ; --tw-ring-inset: ; --tw-ring-offset-width:0px; --tw-ring-offset-color:#fff; --tw-ring-color:rgba(59,130,246,0.5); --tw-ring-offset-shadow:0 0 transparent; --tw-ring-shadow:0 0 transparent; --tw-shadow:0 0 transparent; --tw-shadow-colored:0 0 transparent; --tw-blur: ; --tw-brightness: ; --tw-contrast: ; --tw-grayscale: ; --tw-hue-rotate: ; --tw-invert: ; --tw-saturate: ; --tw-sepia: ; --tw-drop-shadow: ; --tw-backdrop-blur: ; --tw-backdrop-brightness: ; --tw-backdrop-contrast: ; --tw-backdrop-grayscale: ; --tw-backdrop-hue-rotate: ; --tw-backdrop-invert: ; --tw-backdrop-opacity: ; --tw-backdrop-saturate: ; --tw-backdrop-sepia: ; list-style-position: initial; list-style-image: initial; margin-top: 1.25em; margin-bottom: 1.25em; padding: 0px 0px 0px 1rem; counter-reset: item 0; display: flex; flex-direction: column; color: rgb(55, 65, 81); font-family: Söhne, ui-sans-serif, system-ui, -apple-system, &quot;Segoe UI&quot;, Roboto, Ubuntu, Cantarell, &quot;Noto Sans&quot;, sans-serif, &quot;Helvetica Neue&quot;, Arial, &quot;Apple Color Emoji&quot;, &quot;Segoe UI Emoji&quot;, &quot;Segoe UI Symbol&quot;, &quot;Noto Color Emoji&quot;; white-space: pre-wrap; background-color: rgb(247, 247, 248);" class=" list-paddingleft-2"><li><p>Magento 框架</p></li><li><p>Magento 应用程序</p></li><li><p>第三方模块</p></li><li><p>Magento 主题</p></li></ol><p>在每个组件中,module.xml 文件中的 &lt;sequence&gt; 元素可以用来指定该组件依赖的其他组件。这些依赖项将按照它们在 module.xml 文件中的顺序加载。</p><p>例如,如果您的组件依赖于 Magento_Catalog 和 Magento_Sales 模块,您可以在您的组件的 module.xml 文件中添加以下内容:</p><pre>&lt;module&nbsp;name=&quot;MyCompany_MyModule&quot;&nbsp;setup_version=&quot;1.0.0&quot;&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;sequence&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;module&nbsp;name=&quot;Magento_Catalog&quot;/&gt; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;module&nbsp;name=&quot;Magento_Sales&quot;/&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;/sequence&gt; &lt;/module&gt;</pre><p>在上面的示例中,&lt;sequence&gt; 元素定义了 MyCompany_MyModule 组件所依赖的其他两个组件 Magento_Catalog 和 Magento_Sales 的加载顺序。这意味着在加载 MyCompany_MyModule 组件之前,先加载 Magento_Catalog 和 Magento_Sales 组件。</p><p>如果两个或多个组件都依赖于同一个组件,那么在加载这些组件时,该依赖组件只会被加载一次。例如,如果 MyCompany_Module1 和 MyCompany_Module2 两个组件都依赖于 Magento_Catalog 组件,那么在加载 MyCompany_Module1 和 MyCompany_Module2 组件时,Magento_Catalog 组件只会被加载一次。</p><p>在 Magento 2 中,组件的加载顺序非常重要,您应该明确每个组件的依赖关系,并按照正确的顺序加载它们,以确保您的 Magento 2 应用程序正常运行。</p><p><br/></p>

magento2中的命名一个组件以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在 Magento 2 中,为了确保模块命名的一致性和避免命名冲突,建议采用以下方式命名模块:</p><p><br/></p><p>前缀:模块名称应以 VendorName_ 开头,其中 VendorName 是模块开发者的名称或公司名称。</p><p>模块名称:模块名称应尽量简短,同时具有描述性,以便于其他开发者理解该模块的功能。</p><p>后缀:模块名称应以 _ 结尾,后跟模块的类型,例如 Module, Plugin, Observer, Widget 等。</p><p>以下是一个命名示例,假设你的公司名称为 ABC Company,你要创建一个模块来管理客户帐户:</p><p><br/></p><p>前缀:AbcCompany_</p><p>模块名称:CustomerAccount</p><p>后缀:Module</p><p>因此,该模块的完整名称为 AbcCompany_CustomerAccountModule。</p><p><br/></p><p>在 app/code 目录下创建一个名为 AbcCompany/CustomerAccountModule 的目录,然后在该目录下创建一个 registration.php 文件和一个 etc/module.xml 文件,以便 Magento 2 可以识别你的模块。</p><p><br/></p><p>registration.php 文件示例:</p><p><br/></p><p></p><pre class="brush:as3;toolbar:false">&lt;?php use&nbsp;\Magento\Framework\Component\ComponentRegistrar; ComponentRegistrar::register( &nbsp;&nbsp;&nbsp;&nbsp;ComponentRegistrar::MODULE, &nbsp;&nbsp;&nbsp;&nbsp;&#39;AbcCompany_CustomerAccountModule&#39;, &nbsp;&nbsp;&nbsp;&nbsp;__DIR__ );</pre><p><span style="color: #6a9955;"></span><br/></p><p>etc/module.xml 文件示例:</p><p><br/></p><pre class="brush:as3;toolbar:false">&lt;?xml&nbsp;version=&quot;1.0&quot;?&gt; &lt;config&nbsp;xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot;&nbsp;xsi:noNamespaceSchemaLocation=&quot;../../../../../lib/internal/Magento/Framework/Module/etc/module.xsd&quot;&gt; &nbsp;&nbsp;&nbsp;&nbsp;&lt;module&nbsp;name=&quot;AbcCompany_CustomerAccountModule&quot;&nbsp;setup_version=&quot;1.0.0&quot;/&gt; &lt;/config&gt;</pre><p>在创建了这些文件之后,你可以开始在 app/code/AbcCompany/CustomerAccountModule 目录下添加自己的 PHP 类和其他文件。</p><p><br/></p>

magento2中的URN 模式验证以及代码示例

<h5 style="color:red;">系统学习magento二次开发,推荐小册:<a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank">《Magento中文全栈二次开发 》</a></h5> <div class="image-container"> <p> <a style="color:blue;" href="https://www.maxiaoke.com/manual/magento_cn_dev.html" target="_blank"> <img src="https://www.maxiaoke.com/uploads/images/20230218/bb9c82995c24d1105676e02f373755f5.jpg" alt="Magento中文全栈二次开发"> </a> </p> </div> <div class="text-container" style="font-size:14px; color:#888"> <p>本小册面向Magento2以上版本,书代码及示例兼容magento2.0-2.4版本。涵盖了magento前端开发,后端开发,magento2主题,magento2重写,magento2 layout,magento2控制器,magento2 block等相关内容,带领您成为magento开发技术专家。</p> </div> <hr><p>在Magento 2中,可以使用Magento\Framework\DataObject\IdentityInterface接口来实现数据缓存。接口中的方法getIdentities()必须返回用于标识数据对象的唯一标识符。</p><p><br/></p><p>例如,如果您的模型需要缓存,您可以在您的模型类中实现此接口并在getIdentities()方法中返回一个唯一标识符的数组,以便在缓存中正确标识您的数据。</p><p><br/></p><p>以下是一个示例代码:</p><p><br/></p><pre class="brush:as3;toolbar:false">namespace&nbsp;Vendor\Module\Model; use&nbsp;Magento\Framework\DataObject\IdentityInterface; use&nbsp;Magento\Framework\Model\AbstractModel; class&nbsp;CustomModel&nbsp;extends&nbsp;AbstractModel&nbsp;implements&nbsp;IdentityInterface { &nbsp;&nbsp;&nbsp;&nbsp;const&nbsp;CACHE_TAG&nbsp;=&nbsp;&#39;custom_model&#39;; &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;$_cacheTag&nbsp;=&nbsp;&#39;custom_model&#39;; &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;$_eventPrefix&nbsp;=&nbsp;&#39;custom_model&#39;; &nbsp;&nbsp;&nbsp;&nbsp;protected&nbsp;function&nbsp;_construct() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;_init(&#39;Vendor\Module\Model\ResourceModel\CustomModel&#39;); &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;function&nbsp;getIdentities() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;[self::CACHE_TAG&nbsp;.&nbsp;&#39;_&#39;&nbsp;.&nbsp;$this-&gt;getId()]; &nbsp;&nbsp;&nbsp;&nbsp;} }</pre><p>在这个例子中,我们实现了IdentityInterface接口,并且在getIdentities()方法中返回了一个以我们的缓存标记和对象ID为前缀的数组。</p><p><br/></p><p>这样,当我们使用缓存管理器在对象保存或删除时调用clean()或invalidate()方法时,缓存管理器就可以正确地清除或失效相应的缓存。</p><p><br/></p>