Thinkphp 框架扩展之类库扩展操作解析

Thinkphp 框架扩展之类库扩展操作解析

thinkphp 框架扩展之类库扩展操作详解

这篇文章主要介绍了thinkphp 框架扩展之类库扩展操作,结合实例形式分析了Thinkphp 类库扩展的相关原理、实现方法与操作注意事项,需要的朋友可以参考下

本文实例讲述了Thinkphp 框架扩展之类库扩展操作。分享给大家供大家参考,具体如下:

库类扩展

ThinkPHP的类库主要包括公共类库和应用类库,都是基于命名空间进行定义和扩展的。只要按照规范定义,都可以实现自动加载。

公共库类

立即学习PHP免费学习笔记(深入)”;

公共类库通常是指ThinkPHP/Library目录下面的类库,例如:

Think目录:系统核心类库
Org目录:第三方公共类库

这些目录下面的类库都可以自动加载,你只要把相应的类库放入目录中,然后添加或者修改命名空间定义。 你可以在Org/Util/目录下面添加一个Image.class.php 文件,然后添加命名空间如下:

Namespace OrgUtil; class Image { }

这样,就可以用下面的方式直接实例化Image类了:

$image = new OrgUtilImage;

除了这些目录之外,你完全可以在ThinkPHP/Library目录下面添加自己的类库目录,例如,我们添加一个Com目录用于企业类库扩展:

ComSinaApp类(位于Com/Sina/App.class.php )

namespace ComSina; class App { }

ComSinaRank类(位于Com/Sina/Rank.class.php)

namespace ComSina; class Rank { }

公共类库除了在系统的Library目录之外,还可以自定义其他的命名空间,我们只需要注册一个新的命名空间,在应用或者模块配置文件中添加下面的设置参数:

'AUTOLOAD_NAMESPACE' => array(   'Lib'   => APP_PATH.'Lib', )

我们在应用目录下面创建了一个Lib目录用于放置公共的Lib扩展,如果我们要把上面两个类库放到LibSina目录下面,只需要调整为:

LibSinaApp类(位于Lib/Sina/App.class.php )

namespace LibSina; class App { }

LibSinaRank类(位于Lib/Sina/Rank.class.php)

namespace LibSina; class Rank { }

如果你的类库没有采用命名空间的话,需要使用import方法先加载类库文件,然后再进行实例化,例如: 我们定义了一个Counter类(位于Com/Sina/Util/Counter.class.php):

class Counter { }

在使用的时候,需要按下面方式调用:

import('Com.Sina.Util.Couter'); $object = new Counter();

应用类库

应用类库通常是在应用或者模块目录下面的类库,应用类库的命名空间一般就是模块的名称为根命名空间,例如: HomeModelUserModel类(位于ApplicationHomeModel)

namespace HomeModel;

use ThinkModel;

class UserModel extends Model{

}

CommonUtilPay类(位于ApplicationCommonUtil)

namespace CommonUtil; class Pay { }

AdminApiUserApi类(位于ApplicationAdminApi)

namespace AdminApi; use ThinkModel; class UserApi extends Model{ }

记住一个原则,命名空间的路径和实际的文件路径对应的话 就可以实现直接实例化的时候自动加载。

推荐教程:《PHP视频教程

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享