# 本土化
- [簡介](#introduction)
- [提取語句](#retrieving-language-lines)
- [語句中的參數替換](#replacing-parameters-in-language-lines)
- [復數](#pluralization)
- [重寫擴展包的語言包](#overriding-package-language-files)
<a name="introduction"></a>
## 簡介
Laravel 的本地化功能提供方便的方法來獲取多語言的字符串,讓你的網站可以簡單的支持多語言。
語言包存放在 `resources/lang` 目錄下的文件里。在此目錄中應該有應用對應支持的語言并將其對應到每一個子目錄:
/resources
/lang
/en
messages.php
/es
messages.php
語言包簡單地返回鍵值和字符串數組,例如:
<?php
return [
'welcome' => 'Welcome to our application'
];
### 切換語言
應用的默認語言保存在 `config/app.php` 配置文件中。當然,你可以根據需求自由的修改當前設置,可以使用 `App` facade 的 `setLocale` 方法動態地更改現有語言:
Route::get('welcome/{locale}', function ($locale) {
App::setLocale($locale);
//
});
你也可以設置 「備用語言」 ,它將會在當現有語言沒有指定語句時被使用。就像默認語言那樣,備用語言也可以在 `config/app.php` 配置文件設置:
'fallback_locale' => 'en',
#### 指定當前語言
你可以使用 `App` facade 的 `getLocale` 及 `isLocale` 方法指定當前的語言環境或者檢驗當前語言是否是給定的值:
$locale = App::getLocale();
if (App::isLocale('en')) {
//
}
<a name="retrieving-language-lines"></a>
## 提取語句
你可以使用 `trans` 輔助函數來獲取語言字符串,`trans` 方法接受文件名和鍵值作為其第一個參數。例如,讓我們提取 `resources/lang/messages.php` 中的 `welcome` :
echo trans('messages.welcome');
當然,如果你使用 [Blade 模板引擎](/docs/{{version}}/blade), 那么你可以在視圖文件中使用 `{{ }}` 語法或者使用 `@lang` 命令來輸出語句:
{{ trans('messages.welcome') }}
@lang('messages.welcome')
如果指定的語句不存在,`trans` 方法則會簡單的返回這個鍵名。所以,如果上述示例中的鍵不存在,那么 `trans` 方法則會返回 `messages.welcome` 。
<a name="replacing-parameters-in-language-lines"></a>
### 語句中的參數替換
如果需要,你也可以在語句中定義占位符。所有的占位符都使用的 `:` 開頭。例如,你可以自定義一則歡迎消息的占位符:
'welcome' => 'Welcome, :name',
你可以在 `trans` 方法中傳遞一個數組作為第二個參數,它會將數組的值替換到語言內容的占位符中:
echo trans('messages.welcome', ['name' => 'dayle']);
如果你的占位符中包含了首字母大寫或者全體大寫,翻譯過來的內容也會相應的做相應的處理:
'welcome' => 'Welcome, :NAME', // Welcome, DAYLE
'goodbye' => 'Goodbye, :Name', // Goodbye, Dayle
<a name="pluralization"></a>
### 復數
復數是個復雜的問題,不同語言對于復數有不同的規則。使用管道符 `|` ,可以區分單復數字符串格式:
'apples' => 'There is one apple|There are many apples',
接著,你可以使用 `trans_choice` 方法來設置總數。例如,當總數大于一時將會獲取復數語句:
echo trans_choice('messages.apples', 10);
因為 laravel 的翻譯器是基于 Symfony 翻譯擴展包的,因此你甚至可以使用更復雜的復數規則:
'apples' => '{0} There are none|[1,19] There are some|[20,Inf] There are many',
<a name="overriding-package-language-files"></a>
## 重寫擴展包的語言包
部分擴展包帶有自己的語言包,你可以通過在 `resources/lang/vendor/{package}/{locale}` 放置文件來重寫它們,而不是直接修改擴展包的核心文件。
例如,你需要重寫 `skyrim/hearthfire` 擴展包的英文語言包 `messages.php` ,則需要把文件放置在 `resources/lang/vendor/hearthfire/en/messages.php` 。所有沒有重寫的語句仍將會從擴展包的語言包中被加載。
## 譯者署名
| 用戶名 | 頭像 | 職能 | 簽名 |
|---|---|---|---|
| [@江邊望海](http://blog.jiangbianwanghai.com) | <img class="avatar-66 rm-style" src="https://dn-phphub.qbox.me/uploads/avatars/5306_1470714129.jpeg?imageView2/1/w/100/h/100"> | 翻譯 | 鄭州悉知資深技術經理、講師,10多年軟件產品研發、測試、咨詢及管理工作經驗。Follow me [@jiangbianwanghai](https://github.com/jiangbianwanghai/) at Github |
| [@summerblue](https://github.com/summerblue) | <img class="avatar-66 rm-style" src="https://avatars2.githubusercontent.com/u/324764?v=3&s=100"> | Review | A man seeking for Wisdom. |
- 說明
- 翻譯說明
- 發行說明
- 升級說明
- 貢獻導引
- 入門指南
- 安裝
- 配置信息
- 文件夾結構
- 錯誤與日志
- 開發環境
- HomeStead
- Valet
- 核心概念
- 服務容器
- 服務提供者
- 門面(facades)
- contracts
- HTTP層
- 路由
- 中間件
- CSRF保護
- 控制器
- 請求
- 響應
- Session
- 表單驗證
- 視圖與模板
- 視圖
- Blade模板
- 本地化
- Javascript與CSS
- 入門指南
- laravel-elixir
- 安全
- 用戶認證
- 用戶授權
- 重置密碼
- API授權
- 加密解密
- 哈希
- 綜合話題
- 廣播系統
- 緩存系統
- 事件系統
- 文件存儲
- 郵件發送
- 消息通知
- 隊列
- 數據庫
- 快速入門
- 查詢構造器
- 分頁
- 數據庫遷移
- 數據填充
- redis
- Eloquent ORM
- 快速入門
- 模型關聯
- Eloquent集合
- 修改器
- 序列化
- Artisan控制臺
- Artisan 命令行
- 任務調度
- 測試
- 快速入門
- 應用程序測試
- 數據庫測試
- 模擬器
- 官方擴展包
- Cashier交易包
- Envoy 部署工具
- Passport OAuth 認證
- Scout 全文搜索
- Socialite 社交化登錄
- 附錄
- 集合
- 輔助函數
- 擴展包開發
- 交流說明