Explication détaillée de l'espace de noms du framework thinkPHP5.0

不言
Libérer: 2023-03-25 10:24:01
original
2072 Les gens l'ont consulté

Cet article présente principalement l'espace de noms du framework thinkPHP5.0 et combine des exemples spécifiques avec une analyse détaillée des concepts, des fonctions et des méthodes d'utilisation associées des espaces de noms dans thinkPHP5.0. Les amis dans le besoin peuvent s'y référer

Cet article décrit l'espace de noms du framework thinkPHP5.0 avec des exemples. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Espace de noms

ThinkPHP utilise la méthode de l'espace de noms pour définir et charger automatiquement les fichiers de bibliothèque de classes, résolvant ainsi efficacement le problème. des conflits multi-modules et d'espace de noms entre les bibliothèques de classes Composer, et un mécanisme de chargement automatique plus efficace pour les bibliothèques de classes a été implémenté.

Si vous n'êtes pas clair sur le concept de base de l'espace de noms, vous pouvez vous référer au manuel PHP : PHP Namespace

Une remarque spéciale est que,

Si vous devez appeler le PHP intégré dans la bibliothèque de classe, ou dans une bibliothèque tierce. Pour les bibliothèques de classe qui n'utilisent pas d'espaces de noms, pensez à ajouter lors de l'instanciation de la bibliothèque de classe, par exemple :

// 错误的用法
$class = new stdClass();
$xml = new SimpleXmlElement($xmlstr);
// 正确的用法
$class = new \stdClass();
$xml = new \SimpleXmlElement($xmlstr);
Copier après la connexion

dans ThinkPHP5.0, il vous suffit de définir correctement l'espace de noms où se trouve la bibliothèque de classes, et le chemin de l'espace de noms est cohérent avec le répertoire du fichier de bibliothèque de classe, le chargement automatique de la classe peut alors être réalisé , obtenant ainsi un véritable chargement paresseux.

Par exemple, la classe thinkcachedriverFile est définie comme :

namespace think\cache\driver;
class File
{
}
Copier après la connexion

Si nous instancions cette classe, elle devrait être :

$class = new \think\cache\driver\File();
Copier après la connexion

Le système chargera automatiquement le fichier de classe correspondant au chemin de cette classe. Le chemin où il se trouve est thinkphp/library/think/cache/driver. /Fichier.php.

La spécification de répertoire par défaut de la version 5.0 est en minuscules, le nom des fichiers de classe est en casse chameau et la première lettre est en majuscule.

En principe, les répertoires nommés en casse chameau peuvent être supportés, à condition que la définition de l'espace de noms soit cohérente avec le répertoire , par exemple :

On instancie

$class = new \Think\Cache\Driver\File();
Copier après la connexion

Le système chargera automatiquement le fichier thinkphp/library/Think/Cache/Driver/File.php.

Espace de noms racine (package de bibliothèque de classes)

L'espace de noms racine est un concept clé. En prenant la classe thinkcachedriverFile ci-dessus comme exemple, think est un espace de noms racine correspondant. Le répertoire d'espace de noms initial est le répertoire de la bibliothèque de classes du système (thinkphp/library/think). On peut simplement comprendre qu'un espace de noms racine correspond à un package de bibliothèque de classes.

Plusieurs espaces de noms racine (packages de bibliothèques de classes) intégrés au système sont les suivants :


名称描述类库目录
think系统核心类库thinkphp/library/think
traits系统Trait类库thinkphp/library/traits
app应用类库application


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

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

Route::get('hello','index/hello');
Copier après la connexion

请自行使用:

use think\Route
Copier après la connexion

或者:

\think\Route::get('hello','index/hello');
Copier après la connexion

自动注册

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

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

namespace my;
class Test
{
 public function sayHello()
 {
  echo 'hello';
 }
}
Copier après la connexion

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

$Test = new \my\Test();
$Test->sayHello();
Copier après la connexion

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

define('EXTEND_PATH','../vendor/');
Copier après la connexion

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

手动注册

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

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

\think\Loader::addNamespace('my','../application/extend/my/');
Copier après la connexion

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

\think\Loader::addNamespace([
 'my' => '../application/extend/my/',
 'org' => '../application/extend/org/',
]);
Copier après la connexion

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

'root_namespace' => [
 'my' => '../application/extend/my/',
 'org' => '../application/extend/org/',
]
Copier après la connexion

应用类库包

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

namespace app\index\model;
class User extends \think\Model
{
}
Copier après la connexion

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

namespace app\admin\Event;
class User
{
}
Copier après la connexion

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

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

'app_namespace' => 'application',
Copier après la connexion

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

namespace application\index\model;
class User extends \think\Model
{
}
Copier après la connexion

命名空间别名

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

namespace app\index\model;
use think\Model;
class User extends Model
{
}
Copier après la connexion

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

namespace app\index\controller;
use app\index\model\User;
class Index
{
 public function index()
 {
  $user = new User();
 }
}
Copier après la connexion

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

\think\Loader::addNamespaceAlias('model','app\index\model');
Copier après la connexion

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

namespace app\index\controller;
use model\User;
class Index
{
 public function index()
 {
  $user = new User();
 }
}
Copier après la connexion

本文后续的章节,均建立在你已经了解PHP命名空间的基础之上,如果不掌握请自行补充PHP基础,否则你在后续的文档和ThinkPHP5.0的学习过程中,对命名空间的缺乏理解会成为你最大的学习障碍。

相关推荐:

thinkphp5 加载静态资源路径与常量的方法

Thinkphp5行为使用方法汇总

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal