原文:
thinkphp學習筆記8—命名空間
新版本(3.2)中採用命名空間的方式定義和載入類庫檔案,解決多個模組之間的衝突問題,並實現了更加高效的自動載入機制。
需要給類庫定義所在的命名空間,命名空間的路徑和類庫檔案的目錄一致,就可以實現類的自動載入,例如org\util\file類的定義為
namespace org\util;class
file
其所在的路徑是thinkphp/library/org/util/file.class.php,我們例項化該類寫法如下:
$class = new \org\util\file();
系統會自動載入上述檔案,這樣就不需要在例項化命名空間定義的類之前匯入類庫檔案了。
根命名空間是乙個很關鍵的概念,以上面的org\util\file類為例,org就是乙個根命名空間,其對應的初始命名空間目錄就是系統的類庫目錄thinkphp/liberary,該目錄下一級子目錄會自動識別為根命名空間,這些命名空間無需註冊就可使用。
我們在library目錄下面新增乙個my根命名空間目錄,然後定義乙個test類如下:
namespace my;class
test
}
將test類儲存在thinkphp/liberary/my/test.class.php,我們就可以直接例項化和呼叫
$test = new\my\test();
$test->sayhello();
模組中的類庫命名空間是以模組名命名,例如:
namespace home\model;class usermodel extends
\think\model
namespace admin\event;class
userevent
3.2.1版本以上允許設定對應用類庫不使用命名空間,在配置檔案中設定如下:
這樣應用類庫中不再需要使用命名空間的定義,但是繼承和呼叫核心類庫的時候還是需要使用命名空間,例如,下面的應用類庫中將不再寫namespace admin\model;
class usermodel extends\think\model
特別注意:如果你需要在3.2版本中例項化php內建的類庫或者第三方的沒有使用命名空間定義的類,需要採用下面的方式:
$class = new\stdclass();
$sxml = new \******xmlelement($xmlstr);
ThinkPHP框架 學習8
乙個控制器在執行的時候,可以例項化另外乙個控制,並通過物件訪問其指定方法。跨控制器呼叫可以節省我們 的工作量,不然的話,同乙個函式就要不同的控制器裡面重新寫一遍 這是件多麼麻煩的事情 例如 有10個頁面,都要現實指定的資料資訊顯示。比如我們 的 會員數目有200萬 這個資訊需要在10個頁面都顯示 這...
ThinkPHP學習筆記
thinkphp中的配置檔案 慣例配置 專案配置 除錯配置 分組配置 讀取配置 動態配置 擴充套件配置 慣例配置 是系統內建的乙個配置檔案 conf convention.php 專案配置 位於專案配置檔案目錄conf下面,檔名是config.php 除錯配置 在開啟除錯模式的狀態下,可以給專案設定...
ThinkPHP學習筆記
當url case insensitive設定為true的時候表示url位址不區分大小寫,這個也是框架在部署模式下面的預設設定。url case insensitive true,支援對變數的型別檢測,但僅僅支援數字型別的約束定義,例如 blog id d blog read 因為操作方法就是控制器...