이 글에서는 thinkPHP5.0 프레임워크 네임스페이스를 주로 소개하고, thinkPHP5.0의 네임스페이스에 대한 개념, 기능, 관련 사용법을 구체적인 예시를 바탕으로 자세히 분석했습니다. 도움이 필요한 친구들이 참고할 수 있습니다
이 글에서는 thinkPHP5를 다음과 같이 설명합니다. 0 프레임워크 네임스페이스. 참조를 위해 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다:
Namespace
ThinkPHP는 네임스페이스 메서드를 사용하여 클래스 라이브러리 파일을 정의하고 자동으로 로드합니다. 이는 여러 모듈과 Composer 클래스 라이브러리 간의 네임스페이스 충돌 문제를 효과적으로 해결합니다. 클래스 라이브러리에 대해 보다 효율적인 자동 로딩 메커니즘을 구현했습니다.
네임스페이스의 기본 개념이 명확하지 않은 경우 PHP 매뉴얼: PHP 네임스페이스를 참조하세요.
특별히 참고할 점은 PHP의 내장 클래스 라이브러리 또는 타사 클래스 라이브러리를 호출해야 하는 경우입니다. 네임스페이스를 사용하지 않는 경우 클래스 라이브러리를 인스턴스화할 때 를 추가해야 합니다. 예:
// 错误的用法 $class = new stdClass(); $xml = new SimpleXmlElement($xmlstr); // 正确的用法 $class = new \stdClass(); $xml = new \SimpleXmlElement($xmlstr);
ThinkPHP5.0에서는 클래스 라이브러리가 있는 네임스페이스와 클래스 라이브러리의 경로만 올바르게 정의하면 됩니다. 네임스페이스는 클래스 라이브러리 파일의 디렉터리와 일치합니다. 그러면 클래스 자동 로딩을 구현할 수 있으므로 진정한 지연 로딩이 달성됩니다.
예를 들어 thinkcachedriverFile 클래스는 다음과 같이 정의됩니다.
namespace think\cache\driver; class File { }
이 클래스를 인스턴스화하는 경우 다음과 같아야 합니다.
$class = new \think\cache\driver\File();
시스템은 이 경로에 해당하는 클래스 파일을 자동으로 로드합니다. 클래스, 경로는 thinkphp/library/think/cache/driver/File.php입니다.
5.0의 기본 디렉터리 사양은 소문자, 클래스 파일 이름 지정은 카멜 케이스이며 첫 글자는 대문자입니다.
원칙적으로 네임스페이스 정의가 디렉토리와 일치하는 한 낙타 표기로 명명된 디렉토리는 지원될 수 있습니다. 예:
We instantiate
$class = new \think\cache\driver\File();
시스템은 자동으로 thinkphp/를 로드합니다. 라이브러리/Think /Cache/Driver/File.php 파일.
루트 네임스페이스(클래스 라이브러리 패키지)
루트 네임스페이스가 핵심 개념입니다. 위의 thinkcachedriverFile 클래스를 예로 들면 think는 루트 네임스페이스이고 해당 초기 네임스페이스 디렉터리는 시스템의 클래스 라이브러리 디렉터리(thinkphp)입니다. /library/think), 루트 네임스페이스가 클래스 라이브러리 패키지에 해당한다는 것을 간단히 이해할 수 있습니다.
시스템에 내장된 여러 루트 네임스페이스(클래스 라이브러리 패키지)는 다음과 같습니다.
Name | Description | 클래스 라이브러리 디렉토리 |
---|---|---|
think | 시스템 코어 클래스 라이브러리 | thinkphp/library/think |
traits | 시스템 특성 클래스 라이브러리 | thinkphp/library/ 특성 |
app | 응용 프로그램 라이브러리 | application |
如果需要增加新的根命名空间,有两种方式:注册新的根命名空间或者放入EXTEND_PATH目录(自动注册)。
请注意本文中的示例代码为了简洁,如无指定类库的命名空间的话,都表示指的是think命名空间,例如下面的代码:
Route::get('hello','index/hello');
请自行使用:
use think\Route
或者:
\think\Route::get('hello','index/hello');
自动注册
我们只需要把自己的类库包目录放入EXTEND_PATH目录(extend,可配置),就可以自动注册对应的命名空间,例如:
我们在extend目录下面新增一个my目录,然后定义一个\my\Test类( 类文件位于extend/my/Test.php)如下:
namespace my; class Test { public function sayHello() { echo 'hello'; } }
我们就可以直接实例化和调用:
$Test = new \my\Test(); $Test->sayHello();
如果我们在应用入口文件中重新定义了EXTEND_PATH常量的话,还可以改变\my\Test类文件的位置,例如:
define('EXTEND_PATH','../vendor/');
那么\my\Test类文件的位置就变成了/vendor/my/File.php。
手动注册
也可以通过手动注册的方式注册新的根命名空间,例如:
在应用入口文件中添加下面的代码:
\think\Loader::addNamespace('my','../application/extend/my/');
如果要同时注册多个根命名空间,可以使用:
\think\Loader::addNamespace([ 'my' => '../application/extend/my/', 'org' => '../application/extend/org/', ]);
也可以直接在应用的配置文件中添加配置,系统会在应用执行的时候自动注册。
'root_namespace' => [ 'my' => '../application/extend/my/', 'org' => '../application/extend/org/', ]
应用类库包
为了避免和Composer自动加载的类库存在冲突 ,应用类库的命名空间的根都统一以app命名,例如:
namespace app\index\model; class User extends \think\Model { }
其类文件位于 application/index/model/User.php。
namespace app\admin\Event; class User { }
其类文件位于 application/admin/event/User.php。
如果觉得app根命名空间不合适或者有冲突,可以在应用配置文件中修改:
'app_namespace' => 'application',
定义后,应用类库的命名空间改为:
namespace application\index\model; class User extends \think\Model { }
命名空间别名
框架允许给命名空间定义别名,例如:
namespace app\index\model; use think\Model; class User extends Model { }
原来在控制器里面调用方式为:
namespace app\index\controller; use app\index\model\User; class Index { public function index() { $user = new User(); } }
如果我们在应用公共文件中注册命名空间别名如下:
\think\Loader::addNamespaceAlias('model','app\index\model');
那么,上面的控制器代码就可以更改为:
namespace app\index\controller; use model\User; class Index { public function index() { $user = new User(); } }
本文后续的章节,均建立在你已经了解PHP命名空间的基础之上,如果不掌握请自行补充PHP基础,否则你在后续的文档和ThinkPHP5.0的学习过程中,对命名空间的缺乏理解会成为你最大的学习障碍。
相关推荐:
위 내용은 thinkPHP5.0 프레임워크 네임스페이스에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!