前言:
由於我的YII2版本是2.0.7, 設置多語言時和其他教程有不同的地方, 所以想著整理下,方便自己以後需要的時候和有需要的朋友參考學習。下面來一起學習學習吧。
方法如下:
1. 在一個controller裡面寫一個調用i18n的語句, 比如actionIndex
echo \Yii::t('app', 'whatisthis');
現在進入這個頁面, 頁面輸出whatisthis
2. 手動創建一個文件夾messages來存放多語言相關文件, 如果是advanced版本則在frontend下面創建這個文件夾
3. 創建i18n配置文件
yii message/config frontend/messages/config.php
會自動生成一個config.php文件
然後打開frontend/messages/config.php
, language行設置為
'languages' => ['en', 'zh-CN'],
4. 創建message文件, 執行
yii message frontend/messages/config.php
這樣在frontend/messages裡面會生成en和zh-CN文件夾
5. 打開frontend/messages/zh-CH/yii.php
添加一行
'whatisthis' => '這是啥玩意',
6. 在/yii2/frontend/config/main.php
裡設置
components中加入
'i18n' => [ 'translations' => [ 'app*' => [ 'class' => 'yii\i18n\PhpMessageSource', //'basePath' => '@app/messages', //'sourceLanguage' => 'en-US', 'fileMap' => [ 'app' => 'yii.php', 'app/error' => 'error.php', ], ], ], ],
注意, 如果想要更改validate等yii本身的翻譯
需增加下面設置到 'translations' => []
中:
'yii' => [ 'class' => 'yii\i18n\PhpMessageSource', 'sourceLanguage' => 'en-US', 'basePath' => '@app/messages' ],
components同等級後加入
'language' => 'zh-CN',
7. 再刷新頁面, 應該會顯示"這是啥玩意"了.
8. 當你需要新增其他語言時候, 執行第3,4步會重新生成文件, 之前的翻譯(whatisthis)會保留, 但我試了之後發現變成了
'whatisthis' => '@@這是啥玩意@@',
很奇怪的兩邊多出@@.
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。