本文实例讲述了thinkPHP5.0框架命名空间。分享给大家供大家参考,具体如下:
命名空间
ThinkPHP采用命名空间方式定义和自动加载类库文件,有效的解决了多模块和Composer类库之间的命名空间冲突问题,并且实现了更加高效的类库自动加载机制。
如果不清楚命名空间的基本概念,可以参考PHP手册:PHP命名空间
特别注意的是,如果你需要调用PHP内置的类库,或者第三方没有使用命名空间的类库,记得在实例化类库的时候加上 /,例如:
// 错误的用法$class = new stdClass();$xml = new SimpleXmlElement($xmlstr);// 正确的用法$class = new /stdClass();$xml = new /SimpleXmlElement($xmlstr);
在ThinkPHP5.0中,只需要给类库正确定义所在的命名空间,并且命名空间的路径与类库文件的目录一致,那么就可以实现类的自动加载,从而实现真正的惰性加载。
例如,/think/cache/driver/File类的定义为:
namespace think/cache/driver;class File{}
如果我们实例化该类的话,应该是:
$class = new /think/cache/driver/File();
系统会自动加载该类对应路径的类文件,其所在的路径是 thinkphp/library/think/cache/driver/File.php。
5.0默认的目录规范是小写,类文件命名是驼峰法,并且首字母大写。
原则上,可以支持驼峰法命名的目录,只要命名空间定义和目录一致即可,例如:
我们实例化
$class = new /Think/Cache/Driver/File();
系统则会自动加载 thinkphp/library/Think/Cache/Driver/File.php文件。
根命名空间(类库包)
根命名空间是一个关键的概念,以上面的/think/cache/driver/File类为例,think就是一个根命名空间,其对应的初始命名空间目录就是系统的类库目录(thinkphp/library/think),我们可以简单的理解一个根命名空间对应了一个类库包。
系统内置的几个根命名空间(类库包)如下:
名称 | 描述 | 类库目录 |
---|---|---|
think | 系统核心类库 | thinkphp/library/think |
traits | 系统Trait类库 | thinkphp/library/traits |
app | 应用类库 | application |
新闻热点
疑难解答