擴展是專門設計的在 Yii 應用中隨時可拿來使用的, 並可重發布的軟件包。php
例如, yiisoft/yii2-debug 擴展在你的應用的每一個頁面底部添加一個方便用於調試的工具欄, 幫助你簡單地抓取頁面生成的狀況。 你可使用擴展來加速你的開發過程。node
信息:本文中咱們使用的術語 "擴展" 特指 Yii 軟件包。而用術語 "軟件包" 和 "庫" 指代非 Yii 專用的一般意義上的軟件包。
使用擴展要使用擴展,你要先安裝它。大多數擴展以 Composer 軟件包的形式發佈, 這樣的擴展可採起下述兩個步驟來安裝:jquery
修改你的應用的 composer.json 文件,指明你要安裝的是哪一個擴展 (Composer 軟件包)。git
運行 composer install 來安裝指定的擴展。github
注意若是你尚未安裝 Composer ,你須要先安裝。web
默認狀況,Composer安裝的是在 Packagist 中 註冊的軟件包 - 最大的開源 Composer 代碼庫。你能夠在 Packageist 中查找擴展。redis
你也能夠 建立你本身的代碼庫 而後配置 Composer 來使用它。 若是是在開發私有的擴展,而且想只在你的其餘工程中共享時,這樣作是頗有用的。mongodb
經過 Composer 安裝的擴展會存放在 BasePath/vendor 目錄下,這裏的 BasePath 指你的應用的 base path。由於 Composer 仍是一個依賴管理器,當它安裝一個包時, 也將安裝這個包所依賴的全部軟件包。數據庫
例如想安裝 yiisoft/yii2-imagine 擴展,可按以下示例修改你的 composer.json 文件:npm
{ // ... "require": { // ... other dependencies "yiisoft/yii2-imagine": "*" } }
安裝完成後,你應該能在 BasePath/vendor 目錄下見到 yiisoft/yii2-imagine 目錄。你也應該 見到另外一個 imagine/imagine目錄,在其中安裝了所依賴的包。
信息: yiisoft/yii2-imagine 是 Yii 由開發團隊維護一個核心擴展, 全部核心擴展均由 Packagist 集中管理,命名爲yiisoft/yii2-xyz。其中的 xyz, 不一樣擴展有不一樣名稱。
如今你可使用安裝好的擴展了,比如是應用的一部分。
以下示例展現瞭如何使用 yiisoft/yii2-imagine 擴展 提供的yiiimagineImage 類:
use Yii; use yii\imagine\Image; // 生成一個縮略圖 Image::thumbnail('@webroot/img/test-image.jpg', 120, 120) ->save(Yii::getAlias('@runtime/thumb-test-image.jpg'), ['quality' => 50]);
信息: 擴展類由 Yii class autoloader 自動加載。
在極少狀況下,你可能須要手動安裝一部分或者所有擴展,而不是依賴 Composer。 想作到這一點,你應當:
下載擴展壓縮文件,解壓到 vendor 目錄。
若是有,則安裝擴展提供的自動加載器。
按指導說明下載和安裝全部依賴的擴展。
若是擴展沒有提供類的自動加載器,但也遵循了 PSR-4 standard 標準,那麼你可使用 Yii 提供的類自動加載器來加載擴展類。 你須要作的僅僅是爲擴展的根目錄聲明一個 root alias。
例如,假設在 vendor/mycompany/myext 目錄中安裝了一個擴展,而且擴展類的命名空間爲 myext , 那麼你能夠在應用配置文件中包含以下代碼:
[ 'aliases' => [ '@myext' => '@vendor/mycompany/myext', ], ]
在你須要將你的傑做分享給其餘人的時候,你可能會考慮建立一個擴展。 擴展可包括任何你喜歡的代碼,例如助手類、掛件、模塊,等等。
建議你按照 Composer package 的條款建立擴展,以便其餘人更容易安裝和使用。 就像上面的講述的那樣。
如下是將擴展建立爲一個 Composer 軟件包的需遵循的基本步驟。
爲你的擴展建一個工程,並將它存放在版本控制代碼庫中,例如 github.com 。 擴展的開發和維護都應該在這個代碼庫中進行。
在工程的根目錄下,建一個 Composer 所需的名爲 composer.json 的文件。 詳情請參考後面的章節。
在一個 Composer 代碼庫中註冊你的擴展,好比在 Packagist 中,以便其餘 用戶能找到以及用 Composer 安裝你的擴展。
composer.json
每一個 Composer 軟件包在根目錄都必須有一個 composer.json 文件。該文件包含軟件包的元數據。
你能夠在 Composer手冊 中找到完整關於該文件的規格。 如下例子展現了 yiisoft/yii2-imagine 擴展的 composer.json 文件。
{ // package name "name": "yiisoft/yii2-imagine", // package type "type": "yii2-extension", "description": "The Imagine integration for the Yii framework", "keywords": ["yii2", "imagine", "image", "helper"], "license": "BSD-3-Clause", "support": { "issues": "https://github.com/yiisoft/yii2/issues?labels=ext%3Aimagine", "forum": "http://www.yiiframework.com/forum/", "wiki": "http://www.yiiframework.com/wiki/", "irc": "irc://irc.freenode.net/yii", "source": "https://github.com/yiisoft/yii2" }, "authors": [ { "name": "Antonio Ramirez", "email": "amigo.cobos@gmail.com" } ], // package dependencies "require": { "yiisoft/yii2": "*", "imagine/imagine": "v0.5.0" }, // class autoloading specs "autoload": { "psr-4": { "yii\\imagine\\": "" } } }
每一個 Composer 軟件包都應當有一個惟一的包名以便能從其餘的軟件包中識別出來。 包名的格式爲 vendorName/projectName 。
例如在包名 yiisoft/yii2-imagine 中,vendor 名和 project 名分別是 yiisoft 和 yii2-imagine 。
不要用 yiisoft 做爲你的 vendor 名,因爲它被 Yii 的核心代碼預留使用了。
咱們推薦你用 yii2- 做爲你的包名的前綴,表示它是 Yii 2 的擴展,例如,myname/yii2-mywidget。 這更便於用戶辨別是不是 Yii 2 的擴展。
將你的擴展指明爲 yii2-extension 類型很重要,以便安裝的時候 能被識別出是一個 Yii 擴展。
當用戶運行 composer install 安裝一個擴展時, vendor/yiisoft/extensions.php 文件會被自動更新使之包含新擴展的信息。從該文件中, Yii 應用程序就能知道安裝了 哪些擴展 (這些信息可經過 yiibaseApplication::extensions 訪問)。
你的擴展依賴於 Yii (理所固然)。所以你應當在 composer.json 文件中列出它 (yiisoft/yii2)。
若是你的擴展還依賴其餘的擴展或者是第三方庫,你也要一併列出來。 肯定你也爲每個依賴的包列出了適當的版本約束條件 (好比 1.*, @stable) 。 當你發佈一個穩定版本時,你所依賴的包也應當使用穩定版本。
大多數 JavaScript/CSS 包是用 Bower 來管理的,而非 Composer。你可以使用 Composer asset 插件 使之能夠 經過 Composer 來管理這類包。若是你的擴展依賴 Bower 軟件包,你能夠以下例所示那樣簡單地 在 composer.json 文件的依賴中列出它。
{ // package dependencies "require": { "bower-asset/jquery": ">=1.11.*" } }
上述代碼代表該擴展依賴於 jquery Bower 包。
通常來講,你能夠在 composer.json 中用 bower-asset/PackageName 指定 Bower 包,用 npm-asset/PackageName 指定 NPM 包。
當 Compower 安裝 Bower 和 NPM 軟件包時,包的內容默認會分別安裝到@vendor/bower/PackageName 和 @vendor/npm/Packages 下。
這兩個目錄還能夠分別用 @bower/PackageName 和@npm/PackageName 別名指向。
類的自動加載爲使你的類可以被 Yii 的類自動加載器或者 Composer 的類自動加載器自動加載,你應當在 composer.json 中指定 autoload 條目,以下所示:
{ // .... "autoload": { "psr-4": { "yii\\imagine\\": "" } } }
你能夠列出一個或者多個根命名空間和它們的文件目錄。
當擴展安裝到應用中後,Yii 將爲每一個所列出根命名空間建立一個 別名 指向命名空間對應的目錄。 例如,上述的 autoload 條目聲明將對應於別名 @yii/imagine。
擴展意味着會被其餘人使用,你在開發中一般須要額外的付出。 下面咱們介紹一些通用的及推薦的作法,以建立高品質的擴展。
爲避免衝突以及使你的擴展中的類能被自動加載,你的類應當使用命名空間, 並使類的命名符合 PSR-4 standard 或者 PSR-0 standard 標準。
你的類的命名空間應以 vendorNameextensionName 起始,其中 extensionName 和項目名相同,除了它沒有 yii2- 前綴外。例如,對 yiisoft/yii2-imagine 擴展 來講,咱們用 yiiimagine 做爲它的類的命名空間。
不要使用 yii、yii2 或者 yiisoft 做爲你的 vendor 名。這些名稱已由 Yii 內核代碼預留使用了。
有時候,你可能想讓你的擴展在應用的 自舉過程 中執行一些代碼。
例如,你的擴展可能想響應應用的 beginRequest 事件,作一些環境的設置工做。 雖然你能夠指導擴展的使用者顯式地將你的擴展中的事件句柄附加(綁定)到 beginRequest 事件, 可是更好的方法是自動完成。
爲實現該目標,你能夠建立一個所謂 bootstrapping class (自舉類)實現 yiibaseBootstrapInterface 接口。
例如:
namespace myname\mywidget; use yii\base\BootstrapInterface; use yii\base\Application; class MyBootstrapClass implements BootstrapInterface{ public function bootstrap($app) { $app->on(Application::EVENT_BEFORE_REQUEST, function () { // do something here }); } }
而後你將這個類在 composer.json 文件中列出來,以下所示,
{ // ... "extra": { "bootstrap": "myname\\mywidget\\MyBootstrapClass" } }
當這個擴展安裝到應用後,Yii 將在每個請求的自舉過程當中 自動實例化自舉類並調用其 yiibaseBootstrapInterface::bootstrap() 方法。
你的擴展可能要存取數據庫。不要假設使用你的擴展的應用老是用 Yii::$db 做爲數據庫鏈接。你應當在須要訪問數據庫的類中申明一個 db 屬性。 這個屬性容許你的擴展的用戶可定製你的擴展使用哪一個 DB 鏈接。例如, 你能夠參考 yiicachingDbCache 類看一下它是如何申明和使用 db 屬性的。
若是你的擴展須要建立特定的數據庫表,或者修改數據庫結構,你應當
提供 數據遷移 來操做數據庫的結構修改,而不是使用SQL文本文件;
儘可能使遷移文件適用於不一樣的 DBMS;
在遷移文件中避免使用 Active Record。
若是你的擴展是掛件或者模塊類型,它有可能須要使用一些 assets 。 例如,一個模塊可能要顯示一些包含圖片,JavaScript 和 CSS 的頁面。由於擴展的文件 都是放在同一個目錄之下,安裝以後 Web 沒法讀取,你有兩個選擇使得這些 asset 文件目錄 能夠經過 Web 讀取:
讓擴展的用戶手動將這些 asset 文件拷貝到特定的 Web 能夠讀取的文件夾;
申明一個 asset bundle 並依靠 asset 發佈機制自動將這些文件(asset bundle 中列出的文件) 拷貝到 Web 可讀的文件夾。
咱們推薦你使用第二種方法,以便其餘人能更容易使用你的擴展。 更詳細的關於如何處理 assets ,請參照 Assets 章節。
你的擴展可能會在支持不一樣語言的應用中使用!所以,若是你的擴展要顯示內容給終端用戶, 你應當試着實現 國際化和本地化,特別地,
若是擴展爲終端用戶顯示信息,這些信息應該用 Yii::t() 包裝起來,以即可以進行翻譯。 只給開發者參考的信息(如內部異常信息)不須要作翻譯。
若是擴展顯示數字、日期等,你應該用 yiii18nFormatter 中適當的格式化規則作格式化處理。
你必定想讓你的擴展能夠無暇地運行而不會給其餘人帶來問題和麻煩。爲達到這個目的, 你應當在公開發布前作測試。
推薦你建立測試用例,作全面覆蓋的測試你的擴展,而不僅是依賴於手動測試。 每次發佈新版本前,你只要簡單地運行這些測試用例確保一切無缺。 Yii 提供了測試支持,使你更容易寫單元測試、驗收測試和功能測試。 詳情請參照 Testing 章節。
你應該爲每個擴展定一個版本號(如 1.0.1)。咱們推薦你命名版本號時參照 semantic versioning 決定用什麼樣的版本號。
爲使其餘人知道你的擴展,你應該公開發布。
若是你首次發佈一個擴展,你應該在 Composer 代碼庫中註冊它,例如 Packagist。以後,你所須要作的僅僅是在 版本管理庫中建立一個 tag (如v1.0.1),而後通知 Composer 代碼庫。
其餘人就能查找到這個新的發佈了,並可經過 Composer 代碼庫安裝和更新該擴展。
在發佈你的擴展時,除了代碼文件,你還應該考慮包含以下內容 幫助其餘人瞭解和使用你的擴展:
根目錄下的 readme 文件:它描述你的擴展是幹什麼的以及如何安裝和使用。 咱們推薦你用 Markdown 的格式 來寫並將文件命名爲readme.md。
根目錄下的修改日誌文件:它列舉每一個版本的發佈作了哪些更改。該文件能夠用 Markdown 根式 編寫並命名爲 changelog.md。
根目錄下的升級文件:它給出如何從其餘就版本升級該擴展的指導。該文件能夠用 Markdown 根式 編寫並命名爲 changelog.md。
入門指南、演示代碼、截屏圖示等:若是你的擴展提供了許多功能,在 readme 文件中不能完整 描述時,就要用到這些文件。
API 文檔:你的代碼應當作好文檔,讓其餘人更容易閱讀和理解。 你能夠參照 Object class file 學習如何爲你的代碼作文檔。
信息:你的代碼註釋能夠寫成 Markdown 格式。yiisoft/yii2-apidoc 擴展爲你提供了一個從你的 代碼註釋生成漂亮的 API 文檔。
信息:雖然不作要求,咱們仍是建議你的擴展遵循某個編碼規範。 你能夠參照 core framework code style。
Yii 提供了下列核心擴展,由 Yii 開發團隊開發和維護。這些擴展全都在 Packagist 中註冊,並像 Using Extensions 章節描述 的那樣容易安裝。
yiisoft/yii2-apidoc: 提供了一個可擴展的、高效的 API 文檔生成器。核心框架的 API 文檔也是用它生成的。
yiisoft/yii2-authclient: 提供了一套經常使用的認證客戶端,例如 Facebook OAuth2 客戶端、GitHub OAuth2 客戶端。
yiisoft/yii2-bootstrap: 提供了一套掛件,封裝了 Bootstrap 的組件和插件。
yiisoft/yii2-codeception: 提供了基於 Codeception 的測試支持。
yiisoft/yii2-debug: 提供了對 Yii 應用的調試支持。當使用該擴展是, 在每一個頁面的底部將顯示一個調試工具條。 該擴展還提供了一個獨立的頁面,以顯示更詳細的調試信息。
yiisoft/yii2-elasticsearch: 提供對 Elasticsearch 的使用支持。它包含基本的查詢/搜索支持, 並實現了 Active Record 模式讓你能夠將活動記錄 存儲在 Elasticsearch 中。
yiisoft/yii2-faker: 提供了使用 Faker 的支持,爲你生成模擬數據。
yiisoft/yii2-gii: 提供了一個基於頁面的代碼生成器,具備高可擴展性,並能用來快速生成模型、 表單、模塊、CRUD等。
yiisoft/yii2-imagine: 提供了基於 Imagine 的經常使用圖像處理功能。
yiisoft/yii2-jui: 提供了一套封裝 JQuery UI 的掛件以及它們的交互。
yiisoft/yii2-mongodb: 提供了對 MongoDB 的使用支持。它包含基本 的查詢、活動記錄、數據遷移、緩存、代碼生成等特性。
yiisoft/yii2-redis: 提供了對 redis 的使用支持。它包含基本的 查詢、活動記錄、緩存等特性。
yiisoft/yii2-smarty: 提供了一個基於 Smarty 的模板引擎。
yiisoft/yii2-sphinx: 提供了對 Sphinx 的使用支持。它包含基本的 查詢、活動記錄、代碼生成等特性。
yiisoft/yii2-swiftmailer: 提供了基於 swiftmailer 的郵件發送功能。
yiisoft/yii2-twig: 提供了一個基於 Twig 的模板引擎。