Detailed explanation of thinkPHP5.0 framework namespace code

黄舟
Release: 2023-03-06 19:06:02
Original
1594 people have browsed it

This article mainly introduces the thinkPHP5.0 frameworkNamespace, combined with specific examples, a detailed analysis of the concept, function and related usage of namespaces in thinkPHP5.0. Friends in need can refer to the following

The examples in this article describe the thinkPHP5.0 framework namespace. Share it with everyone for your reference, the details are as follows:

Namespace

ThinkPHP adopts namespace definition and automatically loads class library files, which is effective It effectively solves the namespace conflict problem between multiple modules and Composer class library, and implements a more efficient automatic loading mechanism of class libraries.

If you are unclear about the basic concept of namespace, you can refer to the PHP manual: PHP namespace

Special attention Yes, If you need to call PHP's built-in class library, or a third-party class library that does not use the namespace, remember to add \ when instantiating the class library, for example:

// 错误的用法
$class = new stdClass();
$xml = new SimpleXmlElement($xmlstr);
// 正确的用法
$class = new \stdClass();
$xml = new \SimpleXmlElement($xmlstr);
Copy after login

In ThinkPHP5.0, you only need to correctly define the namespace where the class library is located, and the path of the namespace is consistent with the directory of the class library file, then the automatic loading of classes can be achieved, thereby achieving true Lazy loading.

For example, the \think\cache\driver\File class is defined as:

namespace think\cache\driver;
class File
{
}
Copy after login

If we instantiate this class, it should be:

$class = new \think\cache\driver\File();
Copy after login

The system will automatically load it The class file corresponding to the path of this class is thinkphp/library/think/cache/driver/File.php.

5.0 The default directory specification is lowercase, class file naming is camel case, and the first letter is capitalized.

In principle, directories named in camel case can be supported, as long as the namespace definition is consistent with the directory, for example:

We instantiate

$class = new \Think\Cache\Driver\File();
Copy after login

The system will automatically load the thinkphp/library/Think/Cache/Driver/File.php file.

Root namespace (class library package)

The root namespace is a key concept, taking the above \think\cache\driver\File class as an example, think is a root namespace, and its corresponding initial namespace directory is the system's class library directory (thinkphp/library/think). We can simply understand that a root namespace corresponds to a class library package.

Several root namespaces (class library packages) built into the system are as follows:

System Trait class librarythinkphp/library/traitsappApplication Class Libraryapplication


如果需要增加新的根命名空间,有两种方式:注册新的根命名空间或者放入EXTEND_PATH目录(自动注册)

请注意本文中的示例代码为了简洁,如无指定类库的命名空间的话,都表示指的是think命名空间,例如下面的代码:

Route::get('hello','index/hello');
Copy after login

请自行使用:

use think\Route
Copy after login

或者:

\think\Route::get('hello','index/hello');
Copy after login

自动注册

我们只需要把自己的类库包目录放入EXTEND_PATH目录(extend,可配置),就可以自动注册对应的命名空间,例如:

我们在extend目录下面新增一个my目录,然后定义一个\my\Test类( 类文件位于extend/my/Test.php)如下:

namespace my;
class Test
{
 public function sayHello()
 {
  echo 'hello';
 }
}
Copy after login

我们就可以直接实例化和调用:

$Test = new \my\Test();
$Test->sayHello();
Copy after login

如果我们在应用入口文件中重新定义了EXTEND_PATH常量的话,还可以改变\my\Test类文件的位置,例如:

define('EXTEND_PATH','../vendor/');
Copy after login

那么\my\Test类文件的位置就变成了/vendor/my/File.php。

手动注册

也可以通过手动注册的方式注册新的根命名空间,例如:

在应用入口文件中添加下面的代码:

\think\Loader::addNamespace('my','../application/extend/my/');
Copy after login

如果要同时注册多个根命名空间,可以使用:

\think\Loader::addNamespace([
 'my' => '../application/extend/my/',
 'org' => '../application/extend/org/',
]);
Copy after login

也可以直接在应用的配置文件中添加配置,系统会在应用执行的时候自动注册。

'root_namespace' => [
 'my' => '../application/extend/my/',
 'org' => '../application/extend/org/',
]
Copy after login

应用类库包

为了避免和Composer自动加载的类库存在冲突 ,应用类库的命名空间的根都统一以app命名,例如:

namespace app\index\model;
class User extends \think\Model
{
}
Copy after login

其类文件位于 application/index/model/User.php。

namespace app\admin\Event;
class User
{
}
Copy after login

其类文件位于 application/admin/event/User.php。

如果觉得app根命名空间不合适或者有冲突,可以在应用配置文件中修改:

'app_namespace' => 'application',
Copy after login

定义后,应用类库的命名空间改为:

namespace application\index\model;
class User extends \think\Model
{
}
Copy after login

命名空间别名

框架允许给命名空间定义别名,例如:

namespace app\index\model;
use think\Model;
class User extends Model
{
}
Copy after login

原来在控制器里面调用方式为:

namespace app\index\controller;
use app\index\model\User;
class Index
{
 public function index()
 {
  $user = new User();
 }
}
Copy after login

如果我们在应用公共文件中注册命名空间别名如下:

\think\Loader::addNamespaceAlias('model','app\index\model');
Copy after login

那么,上面的控制器代码就可以更改为:

namespace app\index\controller;
use model\User;
class Index
{
 public function index()
 {
  $user = new User();
 }
}
Copy after login

The above is the detailed content of Detailed explanation of thinkPHP5.0 framework namespace code. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
NameDescriptionClass library directory
thinkSystem core class librarythinkphp/library/think
##traits