thinkphp学习笔记9—自动加载

1.命名空间自动加载

在3.2版本中不需要手动加载类库文件,可以很方便的完成自动加载。

系统可以根据类的命名空间自动定位到类库文件,例如定义了一个类Org\Util\Auth类:

namespace Org\Util;
class Auth {
}

保存到ThinkPHP/Library/Org/Util/Auth.class.php

这样我们就可以直接实例化了,

new \Org\Util\Auth();

实例化之后系统会自动加载

ThinkPHP/Library/Org/Util/Auth.class.php

框架Liberary目录下的命名空间都可以自动识别和定位,如下

  1. Library 框架类库目录
  2. │ ├─Think 核心Think类库包目录
  3. │ ├─Org Org类库包目录
  4. │ ├─ ... 更多类库目录

Library目录下的子目录都是一个根命名空间,就是说Think,Org下的类都可以自动加载

new Think\Cache\Driver\File();
new Org\Util\Auth();
new Org\Io\File();

都可以自动加载对应的类库文件。

我们还可以在Liberary目录下面任意增加新的目录,就会自动注册成为一个新的根命名空间,如下:

‘AUTOLOAD_NAMESPACE‘ => array(    ‘My‘     => THINK_PATH.‘My‘,    ‘One‘    => THINK_PATH.‘One‘,)

配置了上面的AUTOLOAD_NAMESPACE之后可以实例化下面的类库

new My\Net\IpLocation();
new One\Util\Log();

自动加载下面的类库文件

ThinkPHP/My/Net/IpLocation.class.php
ThinkPHP/One/Util/Log.class.php

如果命名空间不在Library目录下面,并且没有定义对应的AUTO_LOADNAMESPACE参数的话则会当做模块的命名空间自动加载,例如

new Home\Model\UserModel();
new Home\Event\UserEvent();

这跳跃有点大,刚才讲的还是Liberary下的命名空间,现在又扯到Application下的。

由于ThinkPHP/Library目录下面不存在Home目录,也没在AUTOLOAD_NAMESPACE参数定义Home命名空间,所以就把Home当成模块命名空间来识别,所以会自动加载

Application/Home/Model/UserModel.class.php
Application/Home/Event/UserEvent.class.php

这些命名空间貌似都是ThinkPHP\Liberary目录下的,这个目录下的东西一般不会修改的啊,不明白为什么没有说Application目录下的命名空间。

2.类库映射

定义了较多的命名空间效率会有所影响,可以给常用的类库定义类库映射,命名空间映射相当于给类文件定义了一个别名,例如:

Think\Think::addMap(‘Think\Log‘,THINK_PATH.‘Think\Log.php‘);
Think\Think::addMap(‘Org\Util\Array‘,THINK_PATH.‘Org\Util\Array.php‘);

那这段应该写在哪里呢,文档没有说清楚。也可使用addMap方法批量导入类库映射定义,如下:

$map = array(‘Think\Log‘=>THINK_PATH.‘Think\Log.php‘,‘Org\Util\Array‘=>THINK_PATH.‘Org\Util\Array.php‘);Think\Think::addMap($map);

文档中依旧没有说明这段应该写在什么地方,是config.php还是入口文件里呢,捉急啊。

3.类库加载的优先级

在实际的类库加载过程中,往往会涉及到自动加载优先级的问题,以Test\MyClass为例,自动加载的优先级顺序如下:

1.判断是否注册了Test\MyClass类库映射,如果有则自动加载类库映射定义的文件,

2.判断是否存在Liberary\Test目录,有则以该目录为初始目录加载

3.判断是否注册了Test根命名空间,有则以注册的目录为初始目录加载

4.以上都不成立则以Test模块模块经行初始目录加载,

4.手动加载第三方类库

使用第三方类库的时候可能出现以下情况,不符合ThinkPHP命名空间和后缀,没有使用命名空间或者命名空间和路径不一致,我们可以使用手动导入的方式加载。

我们使用import方法导入类库,如下:

// 导入Org类库包Library/Org/Util/Date.class.php类库
import("Org.Util.Date");
// 导入Home模块下面的 Application/Home/Util/UserUtil.class.php类库
import("Home.Util.UserUtil");
// 导入当前模块下面的类库
import("@.Util.Array");
// 导入Vendor类库包 Library/Vendor/Zend/Server.class.php
import(‘Vendor.Zend.Server‘);

对于import方法,系统会自动识别导入类库文件的位置,ThinkPHP可以自动识别的类库包括Think,Org,Com,Behavior,Vendor,以及Liberary目录下的子目录,这不扯犊子啊,Think,Org,Com,Behavior,Vendor就在ThinkPHP\Liberary下,文档中所说的Liberary目录是指那个目录呢?哦,有可能文档中所说的是Liberary目录下自己新建的目录,有可能。

如果在Liberary目录下新建了一个Test目录,并创建了一个UserTest.class.php文件可以这样导入:

import(‘Test.UserTest‘);

注意如果没有使用namespace来定义命名空间的话,实例化的时候需要使用根命名空间,如下:

import(‘Test.UserTest‘);
$test = new \UserTest();

按照系统规则,import方法是无法导入具有点号的类库文件,因为点号会直接转化为斜线,例如如果我们定义了一个User.Info.class.php文件的话采用import("Org.User.Info");方式加载就会出现错误,导致我们加载到的不是Org/User.Info.class.php文件,而是Org/User/Info.class.php文件,这种情况下我们使用import("Org.User#Info");方式导入,这个就是说文件名中的点号用#代替。

大多数情况下import可以自动识别导入类库文件的位置,特殊情况下需要第二个参数来指定起始导入的路径,例如:要导入当前文件所在目录下的RBAC/AccessDecisionManager.class.php 文件,可以使用import("RBAC.AccessDecisionManager",dirname(__FILE__)); 。 如果要导入的文件后缀不是class.php而是.php,可以使用第三个参数import("RBAC.AccessDecisionManager",dirname(__FILE__),".php");

如果第三方的类库放在Vendor目录下,以.php为文件后缀,也没有采用命名空间可以采用系统内部的Vendor函数简化导入,例如我们要把Zend的Filter\Dir.php放到Vendor目录下面,这个时候Dir文件的路径就是Vendor\Zend\Filter\Dir.php,使用Vendor方法导入如下:

Vendor(‘Zend.Filter.Dir‘);

Vendor方法也可以支持和import一样的基础路径和文件后缀参数,如下:

Vendor(‘Zend.Filter.Dir‘,dirname(__FILE__),‘.class.php‘);

感觉高上大的,这些貌似是对系统进行扩展的时候使用的比较多。

thinkphp学习笔记9—自动加载,布布扣,bubuko.com

时间: 2024-10-04 20:10:02

thinkphp学习笔记9—自动加载的相关文章

ThinkPHP 3.2.3 自动加载公共函数文件的方法

方法一.加载默认的公共函数文件 在 ThinkPHP 3.2.3 中,默认的公共函数文件位于公共模块 ./Application/Common 下,访问所有的模块之前都会首先加载公共模块下面的配置文件(Conf/config.php)和公共函数文件(Common/function.php),即默认的公共函数文件为 ./Application/Common/Common/function.php. 例如,在 ./Application/Common/Common 下新建 function.php,

Android学习笔记--实现正在加载圆圈,加完完成自动取消

今天学到了,网络加载数据 没加载之前是显示正在加载,加载之后 正在加载四个字消失不见,这里要用到一个自定义控件 TipInfoLayout.java 这个是自定义组件的代码 复制粘贴就好 1 package com.wuxianedu.wxhlcorelibrary.widget; 2 3 import android.content.Context; 4 import android.util.AttributeSet; 5 import android.view.LayoutInflater

Hibernate学习笔记(八) — 懒加载与抓取策略

懒加载(Load On Demand)是一种独特而又强大的数据获取方法,它能够在用户滚动页面的时候自动获取更多的数据,而新得到的数据不会影响原有数据的显示,同时最大程度上减少服务器端的资源耗用.总结一句话:什么时候需要数据,什么时候加载. 一.懒加载 1.1 类的懒加载 由javassist产生的代理类与Classes类是继承关系, session.load()方法产生的是代理对象,该代理类是持久化类的子类 /** * 类的懒加载 */ @Test public void testClass_l

PHP学习-类的自动加载

其实我也搞不懂类的自动加载有什么用,只当是记录一下学习过程. 1.使用__autoload($className)方法 比如说,有一个外部的类,我们需要另一个php文件中读取,通常可以使用__autoload方法来加载. 例如: 有一个Person类: 1 <?php 2 class Person{ 3 4 } 我们在另一个php文件构造这个Person类的对象. 1 function __autoload($className){ 2 require $className . ".php

ExtJS学习笔记3:加载、提交和验证表单

加载数据 1.比较好用的设置form数据的方法: formPanel.getForm().setValues([{id: 'FirstName', value: 'Joe'}]); 其中id值为form中field的name属性值,value为要赋的值 2.通过对象赋值: Ext.define('Request', { extend: 'Ext.data.Model', fields: [ 'FirstName', 'LastName', 'EmailAddress', 'TelNumberCo

Android学习笔记---使用Volley加载图片

Volley加载图片 ImageLoader使用法ImageLoader imageLoader = new ImageLoader(requestQueue,new ImageLoood()); ImageLoader.ImageListener imageListener = imageLoader.getImageListener(imageView,R.mipmap.ic_launcher,R.mipmap.ic_launcher); imageLoader.get(strUrl,ima

【EF学习笔记08】----------加载关联表的数据 显式加载

显式加载 讲解之前,先来看一下我们的数据库结构:班级表 学生表 加载从表集合类型 //显示加载 Console.WriteLine("=========查询集合==========="); using (var db = new Entities()) { var query = from v in db.Classes where v.ClassName == "机电10501" select v; var cls = query.Single(); db.Ent

【EF学习笔记06】----------加载关联表的数据 延迟加载

讲解之前,先来看一下我们的数据库结构:班级表 学生表 延迟加载 //延迟加载 using (var db = new Entities()) { //查询班级 var classes = (from v in db.Classes where v.ClassName == "机电10501" select v).Single(); if (classes.Student != null) { //遍历该班级所有学生 foreach (var st in classes.Student)

【EF学习笔记07】----------加载关联表的数据 贪婪加载

讲解之前,先来看一下我们的数据库结构:班级表 学生表 贪婪加载 //贪婪加载 using (var db = new Entities()) { var classes = db.Classes.Where(v => v.ClassName == "机电10502").Include(v => v.Student); foreach (var cls in classes) { Console.WriteLine("============"+cls.C