thinkphp扩展指南

thinkphp扩展指南

ID:14386979

大小:52.50 KB

页数:24页

时间:2018-07-28

thinkphp扩展指南_第1页
thinkphp扩展指南_第2页
thinkphp扩展指南_第3页
thinkphp扩展指南_第4页
thinkphp扩展指南_第5页
资源描述:

《thinkphp扩展指南》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、ThinkPhp扩展指南扩展指南ThinkPHP是一个轻量级的WEB应用开发框架,也就意味着自身并没有庞大的外围应用类库,也不可能仅仅通过核心来解决百分百的应用需求,而这些完全可以通过系统内建的扩展机制来扩展和完善。下面我们会详细介绍如何对你的ThinkPHP应用在不修改核心的情况下进行轻松的扩展。基类库扩展ThinkPHP的基类库目录位于ThinkPHPLib,默认的基类库只包含Think类库包。系统基类库可以很方便的进行扩展,目前支持的类库包包括ORG(第三方公共类库包)和Com(企业类库包)。你可以在ORG类库目录下面添加自己需要的类库(ThinkPHP基类库的所有类库文

2、件统一使用class.php作为后缀,并且文件名和类名相同),你甚至还可以创建属于自己企业的类库,只需要在ThinkPHPLib目录下面创建Com目录,然后在里面增加相应的类库就可以方便的使用import方法导入了。例如,我们在ThinkPHPLibCom下面创建了Sina目录,并且放了UtilUnitTest.class.php类库文件,可以使用下面的方式导入import('Com.Sina.Util.UnitTest');应用类库扩展项目类库的扩展,和基类库的扩展一样,我们可以在项目类库目录增加你想要的子目录,例如,我们在MyApp的项目目录下面增加Common和

3、Util目录,就可以这样加载这些目录下面的类库文件了:import('MyApp.Util.UnitTest');import('@.Common.CommonUtil');第三方类库扩展如果你直接使用的是第三方的类库包,或者是类名和后缀和ThinkPHP的默认规则不符合的,我们建议你放到ThinkPHPVendor目录下面,并使用vendor方法来导入。例如,我们把Zend的FilterDir.php放到Vendor目录下面,这个时候Dir文件的路径就是VendorZendFilterDir.php,我们使用vendor方法导入就是:Vendor('Zend.Filt

4、er.Dir');应用扩展应用扩展是指不改变现有底层框架的基础上,对App类进行额外的功能扩展,系统使用了标签扩展的方式。要启用应用扩展支持,必须在项目配置文件里面开启APP_PLUGIN_ON配置参数。'APP_PLUGIN_ON'=>true,一旦开启后,系统就会检查下面的标签:²app_begin:应用开始标签²app_init:应用初始化标签²app_run:应用执行标签²app_end:应用结束标签以上是系统的App应用类内置的一些标签位置,在每个定义的标签位置,都会执行一个tag方法来调用该标签位置需要执行的方法,例如:我们可以看到,标签的执行只是一个很简单的代码,例

5、如://执行应用初始化标签tag('app_init');系统执行到这里的时候,会自动检查标签所对应要执行的方法,并且依次执行。标签对应的执行方法是通过标签配置定义文件,在项目的配置目录下面增加tags.php文件,写入:returnarray(//定义项目初始化标签要执行的方法'app_init'=>array('function1','function2',array('class1','method1')...),...//其他的标签);如果某个标签位置需要传入额外的参数,可以使用tag('app_init',$data);会自动传入要执行的方法,注意参数必须一致才能准确调

6、用。应用标签扩展的方式,其实可以延伸到项目中,我们可以在项目的某些位置手动插入标签位,然后定义外部的标签扩展来执行。根据这样的一个原理,标签扩展可以随意定制。你需要做的仅仅是在需要执行的位置加上tag('标签名称'[,'可选参数'…])即可,然后在tags.php文件里面定义好各个标签要执行的方法,其他的事情系统会自动处理。模块扩展模块扩展可以使得项目方便的动态挂载模块,动态模块只需要在项目配置目录下面定义模块定义文件modules.php,定义格式为:returnarray('moduleName'=>array('导入路径'[,'类名']),);例如,我们定于了一个名称为Ex

7、tend的扩展模块,其模块类的文件路径位于项目的LibModulesExtendAction.class.php,那么定义如下:returnarray('Extend'=>array('@.Modules.Extend'),);一般情况下,类名无需指定,会按照默认的规则去找,如果你的类名和系统规则不一致,就需要指定类名,假如模块文件名是Extend.class.php:returnarray('Extend'=>array('@.Modules.Extend','Extend

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。