gpt4 book ai didi

magento - 所有 Magento 扩展都必须使用辅助类吗?

转载 作者:行者123 更新时间:2023-12-03 22:08:04 27 4
gpt4 key购买 nike

许多扩展(包括我编写的扩展)包括一个帮助类,它只是扩展抽象基类而不添加任何功能。助手通常如下所示:

class MyCompany_MyModule_Helper_Data extends Mage_Core_Helper_Abstract {
}

因此,扩展类仅用于抽象类提供的东西,尤其是用于翻译。另一方面,Magento 中的所有 Block 和 Controller 类都继承了 __()翻译方法 - 在我目前正在开发的扩展中,我甚至不需要调用帮助程序类。

我可以删除助手类并将其从 config.xml 中删除吗? ?我已经尝试过了,扩展似乎可以正常工作,但由于 Magento 的复杂性,我总是有点担心会有我不知道的影响。

最佳答案

如果你从头开始创建一个模块,辅助类并不是绝对必要的。我通常会跳过创建一个,直到需要它。

然而 , 如果任何 XML 文件使用 module属性来指定一个翻译模块,该属性需要解析为一个有效的助手。例如,在这个核心文件中

<!-- File: app/code/core/Mage/Catalog/etc/system.xml -->
<tabs>
<catalog translate="label" module="catalog">
<label>Catalog</label>
<sort_order>200</sort_order>
</catalog>
</tabs>

module="catalog" .通过指定此属性,翻译标签的 Magento 系统代码将如下所示
Mage::helper('catalog')->__('Label');

因此,从目录模块中删除帮助程序会破坏 Magento 的某些部分。

(单部分类别名 catalog 由 Magento 系统代码自动转换为 Mage::helper('catalog/data'))

中使用了这个“帮助分组翻译”功能。许多 Magento 的 XML 文件,而不仅仅是 system.xml (布局、小部件等)。此外,Magento 中的某些系统会推断和/或要求存在用于翻译的辅助模块(访问控制、外部 API 系统等)。

长话短说:如果您从头开始创建模块,请随时将帮助程序排除在外,直到您开始遇到 Magento 无法实例化帮助程序的错误。永远不要从模块中删除现有的助手,如果你想确保你 100% 兼容其他人可能做出的假设,总是包含 Data.php助手类。

关于magento - 所有 Magento 扩展都必须使用辅助类吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14005596/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com