thinkphp3.2命名空間
3.2版本全面採用命名空間方式定義和載入類庫檔案,有效的解決多個模組之間的衝突問題,並且實現了更加高效的類庫自動載入機制。
由於新版完全採用了命名空間的特性,因此只需要給類庫正確定義所在的命名空間,而命名空間的路徑與類庫檔案的目錄一致,那麼就可以實現類的自動載入。 例如,org\util\file
類的定義為:
namespace
org\util
;
class
file
其所在的路徑是thinkphp/library/org/util/file.class.php
,因此,如果我們例項化該類的話:
$class
=new
\org\util\file
();
系統會自動載入thinkphp/library/org/util/file.class.php
檔案。
注意:和3.1不同,我們無需在例項化命名空間定義的類之前匯入類庫檔案了。根命名空間是乙個關鍵的概念,以上面的
org\util\file
類為例,org
就是乙個根命名空間,其對應的初始命名空間目錄就是系統的類庫目錄(thinkphp/library
),library目錄下面的子目錄會自動識別為根命名空間,這些命名空間無需註冊即可使用。
例如,我們在library目錄下面新增乙個my根命名空間目錄,然後定義乙個test類如下:
namespace
my;
class
test
}
test類儲存在thinkphp/library/my/test.class.php
,我們就可以直接例項化和呼叫:
$test
=new
\my\test
();
$test
->
sayhello
();
模組中的類庫命名空間的根都是以模組名命名,例如:
namespace
home
\model
;
class
usermodel
extends
\think\model
namespace
admin
\event
;
class
userevent
其類檔案位於。
ThinkPHP3 2 命名空間隨記
3.2版本全面採用命名空間方式定義和載入類庫檔案,有效的解決多個模組之間的衝突問題,並且實現了更加高效的類庫自動載入機制。命名空間的概念必須了解,否則會成為3.2版本開發的重大障礙。由於新版完全採用了命名空間的特性,因此只需要給類庫正確定義所在的命名空間,而命名空間的路徑與類庫檔案的目錄一致,那麼就...
ThinkPHP3 2 驗證隨記
自動完成 靜態方式 在模型類裡面通過 auto屬性定義處理規則。動態方式 使用模型類的auto方法動態建立自動處理規則。自動驗證 靜態方式 在模型類裡面通過 validate屬性定義驗證規則。動態方式 使用模型類的validate方法動態建立自動驗證規則。定義格式為 array array 驗證欄位...
ThinkPHP3 2 搭載環境
thinkphp是乙個快速 簡單的基於mvc和物件導向的輕量級php開發框架 預設情況下當你執行index.php時只有home模組,如果你需要建立其他模組時需要在入口檔案 index.php 中定義 define bind module admin 繫結入口到admin模組訪問 bind modu...