Detaillierte Erläuterung des ThinkPHP5.0-Framework-Namespace

不言
Freigeben: 2023-03-25 10:24:01
Original
2072 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich den thinkPHP5.0-Framework-Namespace vor und kombiniert spezifische Beispiele mit einer detaillierten Analyse der Konzepte, Funktionen und zugehörigen Verwendungsmethoden von Namespaces in thinkPHP5.0. Freunde in Not können darauf verweisen

Dieser Artikel beschreibt den thinkPHP5.0-Framework-Namespace mit Beispielen. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Namespace

ThinkPHP verwendet die Namespace-Methode, um Klassenbibliotheksdateien zu definieren und automatisch zu laden und so das Problem effektiv zu lösen von Multimodul- und Namespace-Konflikten zwischen Composer-Klassenbibliotheken und ein effizienterer automatischer Lademechanismus für Klassenbibliotheken wurde implementiert.

Wenn Sie sich über das Grundkonzept des Namespace nicht im Klaren sind, können Sie im PHP-Handbuch nachschlagen: PHP-Namespace

Besonderer Hinweis: Wenn Sie PHPs integrierte Denken Sie bei Klassenbibliotheken, die keine Namespaces verwenden, daran, beim Instanziieren der Klassenbibliothek hinzuzufügen, zum Beispiel:

// 错误的用法
$class = new stdClass();
$xml = new SimpleXmlElement($xmlstr);
// 正确的用法
$class = new \stdClass();
$xml = new \SimpleXmlElement($xmlstr);
Nach dem Login kopieren

Nur in ThinkPHP5.0 Es ist notwendig, den Namespace, in dem sich die Klassenbibliothek befindet, korrekt zu definieren, und der Pfad des Namespace stimmt mit dem Verzeichnis der Klassenbibliotheksdatei überein, dann kann ein automatisches Laden der Klasse erreicht werden. Dadurch wird echtes Lazy Loading erreicht.

Zum Beispiel ist die thinkcachedriverFile-Klasse wie folgt definiert:

namespace think\cache\driver;
class File
{
}
Nach dem Login kopieren

Wenn wir diese Klasse instanziieren, sollte sie lauten:

$class = new \think\cache\driver\File();
Nach dem Login kopieren

Das System lädt automatisch die Klassendatei, die dem Pfad dieser Klasse entspricht. Der Pfad, in dem sie sich befindet, ist thinkphp/library/think/cache/driver/File.php .

Die Standardverzeichnisspezifikation von 5.0 ist Kleinschreibung, die Benennung von Klassendateien erfolgt in Kamelbuchstaben und der erste Buchstabe wird groß geschrieben.

Grundsätzlich können Verzeichnisse mit Namen in Kamel-Schreibweise unterstützt werden, sofern die Namespace-Definition mit dem Verzeichnis übereinstimmt, zum Beispiel:

Wir instanziieren

$class = new \Think\Cache\Driver\File();
Nach dem Login kopieren

Das System lädt automatisch die Datei thinkphp/library/Think/Cache/Driver/File.php.

Root-Namespace (Klassenbibliothekspaket)

Am Beispiel der ThinkcachedriverFile-Klasse handelt es sich um einen Root-Namespace Das anfängliche Namespace-Verzeichnis ist das Klassenbibliotheksverzeichnis des Systems (thinkphp/library/think). Wir können einfach verstehen, dass ein Root-Namespace einem Klassenbibliothekspaket entspricht.

Mehrere im System integrierte Root-Namespaces (Klassenbibliothekspakete) sind wie folgt:


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


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

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

Route::get('hello','index/hello');
Nach dem Login kopieren

请自行使用:

use think\Route
Nach dem Login kopieren

或者:

\think\Route::get('hello','index/hello');
Nach dem Login kopieren

自动注册

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

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

namespace my;
class Test
{
 public function sayHello()
 {
  echo 'hello';
 }
}
Nach dem Login kopieren

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

$Test = new \my\Test();
$Test->sayHello();
Nach dem Login kopieren

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

define('EXTEND_PATH','../vendor/');
Nach dem Login kopieren

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

手动注册

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

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

\think\Loader::addNamespace('my','../application/extend/my/');
Nach dem Login kopieren

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

\think\Loader::addNamespace([
 'my' => '../application/extend/my/',
 'org' => '../application/extend/org/',
]);
Nach dem Login kopieren

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

'root_namespace' => [
 'my' => '../application/extend/my/',
 'org' => '../application/extend/org/',
]
Nach dem Login kopieren

应用类库包

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

namespace app\index\model;
class User extends \think\Model
{
}
Nach dem Login kopieren

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

namespace app\admin\Event;
class User
{
}
Nach dem Login kopieren

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

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

'app_namespace' => 'application',
Nach dem Login kopieren

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

namespace application\index\model;
class User extends \think\Model
{
}
Nach dem Login kopieren

命名空间别名

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

namespace app\index\model;
use think\Model;
class User extends Model
{
}
Nach dem Login kopieren

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

namespace app\index\controller;
use app\index\model\User;
class Index
{
 public function index()
 {
  $user = new User();
 }
}
Nach dem Login kopieren

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

\think\Loader::addNamespaceAlias('model','app\index\model');
Nach dem Login kopieren

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

namespace app\index\controller;
use model\User;
class Index
{
 public function index()
 {
  $user = new User();
 }
}
Nach dem Login kopieren

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

相关推荐:

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

Thinkphp5行为使用方法汇总

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des ThinkPHP5.0-Framework-Namespace. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage