類自動加載(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 的自動加載器仍然可以幫你自動加載擴展內的類。