類自動加載(Autoloading)
類自動加載(Autoloading)
Yii 依靠類自動加載機製來定位和包含所需的類文件。它提供一個高性能且完美支持PSR-4 標準(中文漢化)的自動加載器。該自動加載器會在引入框架文件 Yii.php
時安裝好。
注意:為了簡化敘述,本篇文檔中我們隻會提及類的自動加載。不過,要記得文中的描述同樣也適用於接口和Trait(特質)的自動加載哦。
使用 Yii 自動加載器
要使用 Yii 的類自動加載器,你需要在創建和命名類的時候遵循兩個簡單的規則:
- 每個類都必須置於命名空間之下 (比如 foo\bar\MyClass)。
- 每個類都必須保存為單獨文件,且其完整路徑能用以下算法取得:
- // $className 是一個開頭包含反斜杠的完整類名(譯者注:請自行穀歌:fully qualified class name)
- $classFile = Yii::getAlias('@' . str_replace('\\\\', '/', $className) . '.php');
舉例來說,若某個類名為 foo\bar\MyClass
,對應類的文件路徑彆名會是 @foo/bar/MyClass.php
。為了讓該彆名能被正確解析為文件路徑,@foo
或 @foo/bar
中的一個必須是根彆名。
當我們使用基本應用模版時,可以把你的類放置在頂級命名空間 app
下,這樣它們就可以被 Yii 自動加載,而無需定義一個新的彆名。這是因為 @app
本身是一個預定義彆名,且類似於 app\components\MyClass
這樣的類名,基於我們剛才所提到的算法,可以正確解析出 AppBasePath/components/MyClass.php
路徑。
在高級應用模版裡,每一邏輯層級會使用他自己的根彆名。比如,前端層會使用 @frontend
而後端層會使用@backend
。因此,你可以把前端的類放在 frontend
命名空間,而後端的類放在 backend
。 這樣這些類就可以被 Yii 自動加載了。
類映射表(Class Map)
Yii 類自動加載器支持類映射表功能,該功能會建立一個從類的名字到類文件路徑的映射。當自動加載器加載一個文件時,他首先檢查映射表裡有冇有該類。如果有,對應的文件路徑就直接加載了,省掉了進一步的檢查。這讓類的自動加載變得超級快。事實上所有的 Yii 核心類都是這樣加載的。
你可以用 Yii::$classMap
方法向映射表中添加類,
- Yii::$classMap['foo\\bar\\MyClass'] = 'path/to/MyClass.php';
彆名可以被用於指定類文件的路徑。你應該在引導啟動的過程中設置類映射表,這樣映射表就可以在你使用具體類之前就準備好。
用其他自動加載器
因為 Yii 完全支持 Composer 管理依賴包,所以推薦你也同時安裝 Composer 的自動加載器,如果你用了一些自帶自動加載器的第三方類庫,你應該也安裝下它們。
當你同時使用其他自動加載器和 Yii 自動加載器時,應該在其他自動加載器安裝成功之後,再包含 Yii.php
文件。這將使 Yii 成為第一個響應任何類自動加載請求的自動加載器。舉例來說,以下代碼提取自基本應用模版的入口腳本 。第一行安裝了 Composer 的自動加載器,第二行才是 Yii 的自動加載器:
- require(__DIR__ . '/../vendor/autoload.php');
- require(__DIR__ . '/../vendor/yiisoft/yii2/Yii.php');
你也可以隻使用 Composer 的自動加載,而不用 Yii 的自動加載。不過這樣做的話,類的加載效率會下降,且你必須遵循 Composer 所設定的規則,從而讓你的類滿足可以被自動加載的要求。
補充:若你不想要使用 Yii 的自動加載器,你必須創建一個你自己版本的
Yii.php
文件,並把它包含進你的入口腳本裡。
自動加載擴展類
Yii 自動加載器支持自動加載擴展的類。唯一的要求是它需要在 composer.json
文件裡正確地定義 autoload
部分。請參考 Composer 文檔(英文)(中文漢化),來了解如何正確描述 autoload
的更多細節。
在你不使用 Yii 的自動加載器時,Composer 的自動加載器仍然可以幫你自動加載擴展內的類。