扩展机制简介

2022-03-21 13:31:47
禅道团队
5486
最后编辑:朱金勇 于 2022-03-31 10:15:26
分享链接

易软天创团队使用PHP这十几年过程中,也曾经使用过很多PHP开源的软件。在使用过程中,遇到了一个同样的问题:如果对代码做过个性化的修改,就没有办法跟着官方的版本进行升级了。做得稍好一些的比如wordpress, dupral, discuz这些程序后来有了自己的hook扩展机制。但这种扩展机制是基于动作或者事件的,只能对原有的系统做局部的修改,限制性比较强,没有办法对系统做比较深入的修改。带着这个问题,我们在设计zentaoPHP框架的时候,就特别注意框架的扩展性。得益于PHP5.2版本以后oop语法的增强,zentaoPHP框架实现了深入彻底的扩展机制。


禅道的功能都是由一个个的模块组成的,每个模块会对应到module下面的一个目录,比如project、user等模块。每个模块下按照mvc进行划分,有自己的control(控制层)、 model(模型层)和view(视图层)。同时我们还补充了其他几个辅助的概念:config(配置)、lang(语言)、 css(样式)和js(js脚本)。通过zentaoPHP框架的扩展机制,可以实现对任一层的扩展。


1. 针对禅道已有模块,扩展代码的目录结构如下:

extension/custom/user/ext/control/{method1.php, method2.php, ...} 
extension/custom/user/ext/model/{extend1.php, extend2.php, ...}
extension/custom/user/ext/view/{method1.html.php, method2.html.php, ...}
extension/custom/user/ext/config/{config1.php, config2.php, ...}
extension/custom/user/ext/lang/zh-cn/{lang1.php, lang2.php, ...}
extension/custom/user/ext/lang/en/{lang1.php, lang2.php, ...}
extension/custom/user/ext/css/method1/{1.css, 2.css, ...}
extension/custom/user/ext/js/method1/{1.js, 2.js, ...}


2. 针对新增模块,所有代码都需要在extension/custom目录下编写:

extension/custom/oa/control.php
extension/custom/oa/model.php
extension/custom/oa/view/{metho1.html.php, method2.html.php, ...}
extension/custom/oa/config/config.php
extension/custom/oa/css/{method1.css, method2.css, common.css, ...}
extension/custom/oa/js/{method1.js, method2.js, common.js, ...}
     
extension/custom/oa/ext/control/{method1.php, method2.php, ...} 
extension/custom/oa/ext/model/{extend1.php, extend2.php, ...}
extension/custom/oa/ext/view/{method1.html.php, method2.html.php, ...}
extension/custom/oa/ext/config/{config1.php, config2.php, ...}
extension/custom/oa/ext/lang/zh-cn/{lang1.php, lang2.php, ...}
extension/custom/oa/ext/lang/en/{lang1.php, lang2.php, ...}
extension/custom/oa/ext/css/method1/{1.css, 2.css, ...}
extension/custom/oa/ext/js/method1/{1.js, 2.js, ...}

开发者只要按照我们的扩展机制,把相应的扩展代码部署到对应的目录,即可实现对现有功能的重新定义或者新增功能。因为扩展代码和主干代码是分离的,所以就不用担心主干代码升级时会覆盖扩展代码。就可以做到放心的升级。


评论列表
X﹏X 2023-03-20 15:16:55
按文档说明测试了新加模块和已有模块扩展均没有均没有成功
版本17.8
有没有demo那?
arcee 2023-02-23 15:59:20
你好,我按照文档的方式进行扩展,在extension/custom/report/ext/lang/zh-cn/lang1.php文档中代码如下
<?php
$lang->report->task1 = '任务列表1';

$lang->reportList->staff->lists[15] = 'OTA任务表|report|task1';

?>
但是无效,页面上没有正确的显示,不知道是什么原因呢?
1/1
发表评论
评论通过审核后显示。