您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關PHP中命名空間Namespace怎么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
這一特性在 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 文件(雖然這樣看起來并不方便多少)。
關于“PHP中命名空間Namespace怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。