暂定本章为这个系列最后一章,还是继续沿用模块的别名(alias)概念

    <modules>
<Mage_Wishlist>
<version>1.6.0.0</version>
<alias>wishlist</alias>
</Mage_Wishlist>
</modules>

看下Magento通常是怎么定义block、helper和model的别名的

<blocks>
<wishlist>
<class>Mage_Wishlist_Block</class>
</wishlist>
</blocks>
<models>
<wishlist>
<class>Mage_Wishlist_Model</class>
......
</wishlist>
......
</models>

类似于一样前两章所说。blocks和models的别名都是一样的。当然本章改造目的就是通用别名代替上面这样的分别单独配置了。只是这里要先等下,由于我在Mage_Wishlist的config.xml里没有发现对helpers的定义,而Mage_Wishlist的helper类明明都能够正常使用的。为什么呢?

这个系列一開始(“约定优于配置”与Magento)我吐槽了下说Magento是多么的违反“约定优于配置”的范式,这里小小的平反下,Magento还是有地方符合这个范式的。上面讲到为什么没有对helpers进行定义,模块的helper类依旧能够正常使用。原因看Mage_Core_Model_Config类的public
function getGroupedClassName方法

// Second - if entity is not rewritten then use class prefix to form class name
if (empty($className)) {
if (!empty($config)) {
$className = $config->getClassName();
}
if (empty($className)) {
$modules = $this->getAliasConfig();
if($modules[$group]){
$className = $modules[$group].'_'.$groupType;
}
}
if (empty($className)) {
$className = 'mage_'.$group.'_'.$groupType;
}
if (!empty($class)) {
$className .= '_'.$class;
}
$className = uc_words($className);
}

有一段$className = 'mage_'.$group.'_'.$groupType;。意思是当没有在config.xml里指定别名时。自己主动依据$group名去Mage文件夹下寻找相应的helper类,以Mage::helper('wishlist')->calculate();这样的写法为例,这里$group是helper后面括号中的wishlist,这里的$groupType是helper。那么拼接之后的$className就是“mage_wishlist_helper”,就是通过这样的方式,系统提供了一种在未明白定义情况下helper类的一个默认载入路径。

这套逻辑不只对helper类适用,对block和model类一样适用。由于getGroupedClassName是一个block、helper和model共用的方法,详见Mage_Core_Model_Config类里的

public function getBlockClassName($blockType){
......
}
public function getHelperClassName($helperName){
......
}
public function getModelClassName($modelClass){
......
}

所以理论上来说,未对这块代码做改动的情况下。就已经能够把原生模块(core/Mage文件夹下的)的config.xml做一些精简了。比方删掉Mage_Wishlist模块的以下这段配置,并不会对这个模块的正常使用带来不论什么影响

<blocks>
<wishlist>
<class>Mage_Wishlist_Block</class>
</wishlist>
</blocks>

当然Magento官方保留这些配置也不是没有道理,上面提到了说这个默认载入方式仅仅对core/Mage文件夹下的的模块有效,community和local文件夹下的模块都是不符合标准的,必须显式指定配置。假设自带核心模块都把这些配置省了,那用户做二次开发就没參照物了

Magento是一个扩展性相当好的系统,引入各种第三方插件或者自己二次开发功能模块都是非经常见的场景,前面提到原生的“约定”仅仅对core/Mage有效,那么本章要做的改动就是让全部community和local文件夹下的模块在载入block、helper和model时也能够依照某种约定(就是我所定义的模块的别名)来进行,免去显示配置的xml内容。

改动的方法就是之前提到的public function getGroupedClassName,我增加了以下这样一段代码

            if (empty($className)) {
$modules = $this->getAliasConfig();
if($modules[$group]){
$className = $modules[$group].'_'.$groupType;
}
}

详见:https://github.com/walexer/Yli_Coc/blob/master/app/code/local/Mage/Core/Model/Config.php

原理就是用模块的别名(alias)取代显式各自指定的别名,由于核心模块有自己的一套“约定”。我用一个第三方插件模块AW_Blog来说明

定义别名:

    <modules>
<AW_Blog>
<version>1.3.16</version><platform>ce</platform>
<alias>blog</alias>
</AW_Blog>
</modules>

能够删除的配置内容

        <helpers>
<blog>
<class>AW_Blog_Helper</class>
</blog>
</helpers>

<blocks>里面的

            <blog>
<class>AW_Blog_Block</class>
</blog>

<models>里面的

<class>AW_Blog_Model</class>

本系列的改造到这里临时告一段落,相信依照“约定优于配置”的原则,Magento肯定还有地方能够拎出来改一改(毕竟Magento那么的自由),以后有时间的话能够考虑是不是开续集。

下一章会做一下改造前后的性能对照測试。有明显提升的话当然最好,没有明显提升的话就当玩票了,最起码读了不少Magento的底层源代码,总是有收获的。

“约定优于配置”与Magento改造尝试四之block、helper和model载入的更多相关文章

  1. SpringMVC介绍之约定优于配置

    SpringMVC介绍之约定优于配置 所谓的约定优于配置就是指在程序开发过程中我们约定好一些规则可以使我们更少的进行配置和代码编写.就这么简单的一句话可能你还不是很懂什么是约定优于配置,没关系,看完后 ...

  2. convention over configuration 约定优于配置 按约定编程 约定大于配置 PEP 20 -- The Zen of Python

    为什么说 Java 程序员必须掌握 Spring Boot ?_知识库_博客园 https://kb.cnblogs.com/page/606682/ 为什么说 Java 程序员必须掌握 Spring ...

  3. spring boot约定优于配置的这种做法在如今越来越流行了

    约定优于配置的这种做法在如今越来越流行了,它的特点是简单.快速.便捷.但是这是建立在程序员熟悉这些约定的前提上.而 Spring 拥有一个庞大的生态体系,刚开始转到 Spring Boot 完全舍弃 ...

  4. Maven之(八)约定优于配置

    maven的配置文件看似很复杂,其实只需要根据项目的实际背景,设置个别的几个配置项而已.maven有自己的一套默认配置,使用者除非必要,并不需要去修改那些约定内容.这就是所谓的"约定优于配置 ...

  5. spring boot中的约定优于配置

    Spring Boot并不是一个全新的框架,而是将已有的Spring组件整合起来. Spring Boot可以说是遵循约定优于配置这个理念产生的.它的特点是简单.快速和便捷. 既然遵循约定优于配置,则 ...

  6. Struts2注解 及 约定优于配置

    Struts2注解 1 Struts2注解的作用 使用注解可以用来替换struts.xml配置文件!!! 2 导包 必须导入struts2-convention-plugin-2.3.15.jar包, ...

  7. 8.Maven之(八)约定优于配置

    转自:“https://blog.csdn.net/qq_25460531/article/details/79423961” maven的配置文件看似很复杂,其实只需要根据项目的实际背景,设置个别的 ...

  8. 【面试普通人VS高手系列】Spring Boot的约定优于配置,你的理解是什么?

    对于Spring Boot约定优于配置这个问题,看看普通人和高手是如何回答的? 普通人的回答: 嗯, 在Spring Boot里面,通过约定优于配置这个思想,可以让我们少写很多的配置, 然后就只需要关 ...

  9. Spring 4 官方文档学习(十一)Web MVC 框架之约定优于配置

    当返回一个ModelAndView时,可以使用其addObject(Object obj)方法,此时的约定是: An x.y.User instance added will have the nam ...

随机推荐

  1. Open Cascade:如何从AIS_Shape导出TopoDS_Shape?

    Open Cascade:如何从AIS_Shape导出TopoDS_Shape? 实现代码如下: if( !myAISContext->HasOpenedContext()) { wxMessa ...

  2. 题目:企业发放的奖金根据利润提成。 利润(I)低于或等于10万元时,奖金可提10%; 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%; 20万到40万之间时,高于20万元的部分,可提成5%; 40万到60万之间时高于40万元的部分,可提成 3%; 60万到100万之间时,高于60万元的部分,可提成1.5%; 高于100万元时,超过

    题目:企业发放的奖金根据利润提成. 利润(I)低于或等于10万元时,奖金可提10%: 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%: 20万到 ...

  3. Python虚拟环境 之 virtualenv 与 virtualenvwrapper

           在开发Python应用程序的时候,比如系统安装的Python3只有一个版本:3.6.所有第三方的包都会被 pip 安装到Python3的 site-packages 目录下. 如果我们要 ...

  4. CFNetwork framework

    iphone包含了很多框架和库,从底层的套接字到不同层次的封装,可以方便地给程序添加网络功能. (1)BSD套接字.最底层的套接字,这是Unix网络开发常用的API.如果从其他系统移植程序,而程序用的 ...

  5. Swift语言Storyboard教程:第二部

    本文由CocoaChina翻译小组@TurtleFromMars翻译自raywenderlich,原文:Storyboards Tutorial in Swift: Part 2 更新记录:该Stor ...

  6. 14. PARAMETERS

    14. PARAMETERS PARAMETERS表提供有关存储例程(存储过程和存储函数)的参数以及存储函数的返回值的信息. PARAMETERS表不包含内置SQL函数或用户定义函数(UDF). 参数 ...

  7. 快速部署jumpserver堡垒机

    jumpserver版本:Version 1.4.1-2 (社区版) 主机IP地址:10.0.0.105 准备环境1.安装依赖yum -y install wget sqlite-devel xz g ...

  8. 上传文件到Ubuntu阿里云服务器(windows到Linux的文件上传)

    上传文件到Ubuntu阿里云服务器(windows到Linux的文件上传) 最近在阿里云上面租了一个轻量级服务器玩玩,学习学习怎么在服务器部署网站.然后嘞,在想要将本地文件上传到服务器的时候,自己研究 ...

  9. linux find的用法

    ①.一般格式: ·find   path   -option   [   -print ]   [ -exec   -ok   command ]   {} \; 说明: #-print 将查找到的文 ...

  10. kafka flumn sparkstreaming java实现监听文件夹内容保存到Phoenix中

    ps:具体Kafka Flumn SparkStreaming的使用  参考前几篇博客 2.4.6.4.1 配置启动Kafka (1) 在slave机器上配置broker 1) 点击CDH上的kafk ...