PHP 5.3中的命名空間使用方法淺述
PHP 5.3 的一個(gè)新的重要特性就是 命名空間(namespace)。
這一特性在 PHP5.0x 時(shí)候就提出過,后來被取消并安排在 PHP6 中實(shí)現(xiàn)。而此次又再次“提前”到了 PHP 5.3 發(fā)布,可見開發(fā)人員對(duì)其的重視以及謹(jǐn)慎的態(tài)度。
官方發(fā)布時(shí)說明文檔的內(nèi)容可能已過期(documentation maybe out dated),所以在這里簡(jiǎn)單的說明命名空間的用法:首先是聲明一個(gè)命名空間,加入了新的關(guān)鍵字 namespace ,其應(yīng)在類文件的開頭
- <?php
- namespace Project::Module;
- class User {
- const STATUS_OK = true;
- function register($data) {
- ...
- }
- ...
- }
然后在控制器中(可能是其他文件)就可以這樣調(diào)用
- $user = new Project::Module::User();
- $user->register($register_info);
的確與平常的并無兩樣,但是我們可以將兩個(gè)相互獨(dú)立的類聯(lián)系起來。比如
- Project::Module::User;
- Project::Module::Blog;
這樣就能從語言本身更容易描述和理解變量、類之間的關(guān)系,從而避免了“傳統(tǒng)”上的 Project_Module_Blog 這樣冗長(zhǎng)的命名方式。
上面的說明可能很難說明使用命名空間帶來了什么好處,新增加的 use 和 as 關(guān)鍵字或許能更好的說明問題。use 和 as 語句可以引用和聲明 命名空間的“別名”。比如,上述的控制器中實(shí)例化類的代碼可以這樣寫
- use Project::Module;
- $user = new Module::User();
- $user->register($register_info);
甚至
- use Project::Module::User as ModuleUser;
- $user = new ModuleUser;
- $user->register($register_info);
類中的常量也可以通過命名空間訪問,比如上述類中的 STATUS_OK 就可以通過命名空間
- Project::Module::User::STATUS_OK
訪問。進(jìn)一步的,也可以用別名簡(jiǎn)化那么長(zhǎng)的“變量名稱”
- use Project::Module::User::STATUS_OK as STATUS_OK;
- echo STATUS_OK;
順便提下“超空間(The Global Namespace)”的概念。所謂的“超空間”,就是沒有指定命名空間的變量、類和函數(shù)。比如
- function foo() {
- ...
- }
這的函數(shù),可以使用 foo() 執(zhí)行的同時(shí),也可以使用 ::foo(); 這樣執(zhí)行。
最后,配合使用 autoload 函數(shù)即可載入指定命名空間的類。簡(jiǎn)單的函數(shù)如下
- function __autoload( $classname ) {
- $classname = strtolower( $classname );
- $classname = str_replace( '::', DIRECTORY_SEPARATOR, $classname );
- require_once( dirname( __FILE__ ) . '/' . $classname . '.class.php' );
- }
這樣,比如調(diào)用
- __autoload('Project::Module::User');
就可以自動(dòng)載入 Project_Module_User.class.php 文件(雖然這樣看起來并不方便多少)。
【編輯推薦】