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