ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
[TOC] # 本地化 ## 简介 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')) { // } ``` ## 定义翻译字符串 ### 使用短键 所有语言文件都返回键值对数组,例如: ``` <?php // resources/lang/en/messages.php return [ 'welcome' => 'Welcome to our application' ]; ``` ### 使用翻译字符串作为键 Laravel 也支持使用字符串 『默认』 翻译作为关键字来定义翻译字符串。 使用翻译字符串作为键的翻译文件以 JSON 格式存储在`resources/lang`目录中。例如,如果你的应用中有西班牙语翻译,你应该在该目录下新建一个`resources/lang/es.json`文件: ``` { "I love programming.": "Me encanta programar." } ``` ## 检索翻译字符串 可以使用辅助函数`__`从语言文件中检索,`__`函数接受翻译字符串所在的文件名加键名作为其第一个参数。例如,我们要检索`resources/lang/messages.php`语言文件中的翻译字符串`welcome`: ``` echo __('messages.welcome'); echo __('I love programming.'); ``` 在Blade 在视图文件中使用`{{ }}`语法或者使用`@lang`指令来打印翻译字符串: ``` {{ __('messages.welcome') }} @lang('messages.welcome') ``` 如果指定的翻译字符串不存在,那么`__`函数会直接返回该字符串。 >[success] 注意:`@lang`指令不会对任何输出进行转义。当你使用这个指令时,你必须**完全由自己承担**对输出内容的转义工作。 ### 翻译字符串中的参数替换 可以在翻译字符串中定义占位符。所有的占位符都有一个`:`前缀。例如,你可以使用占位符 name 定义欢迎消息: ``` 'welcome' => 'Welcome, :name', ``` 可以在`__`函数中传递一个数组作为第二个参数,它会将数组中的值替换到翻译字符串的占位符中: ``` echo __('messages.welcome', ['name' => 'dayle']); ``` 如果你的占位符中包含了首字母大写或者全部为大写,翻译过来的内容也会做相应的大写处理: ``` 'welcome' => 'Welcome, :NAME', // Welcome, DAYLE 'goodbye' => 'Goodbye, :Name', // Goodbye, Dayle ``` ### 复数 复数是一个复杂的问题,因为不同的语言对复数有不同的规则, 使用 『管道符』`|`,可以区分字符串的单复数形式: ``` 'apples' => 'There is one apple|There are many apples', echo trans_choice('messages.apples', 1); ``` 你甚至可以创建更复杂的复数规则,为多个数字范围指定翻译字符串: ``` 'apples' => '{0} There are none|[1,19] There are some|[20,*] There are many', ``` 在定义具有复数选项的翻译字符串之后,你可以使用`trans_choice`函数来检索给定『数量』 的内容。例如,设置 『总数』 为 10 ,符合数量范围 1 至 19 ,所以会得到 There are some 这条复数语句: ``` echo trans_choice('messages.apples', 10); ``` 你也可以在复数字符串中插入占位符。`trans_choice`函数第三个参数所传递数组将会替换占位符: ``` 'minutes_ago' => '{1} :value minute ago|[2,*] :value minutes ago', echo trans_choice('time.minutes_ago', 5, ['value' => 5]); ``` 如果你想让传递给`trans_choice`函数的 『数量』 参数显示在翻译字符串中,你可以使用`:count`占位符: ``` 'apples' => '{0} There are none|{1} There is one|[2,*] There are :count', echo trans_choice('messages.apples', 10); // There are 10 ``` ## 重写扩展包的语言文件 部分扩展包可能会附带自己的语言文件。你可以通过在`resources/lang/vendor/{package}/{locale}`目录放置文件来重写它们,而不要直接修改扩展包的核心文件。 例如,当你需要重写`skyrim/hearthfire`扩展包的英语语言文件`messages.php`,则需要把文件存放为`resources/lang/vendor/hearthfire/en/messages.php`。在这个文件中,你只需要定义你想要修改的翻译字符串。任何没有被重写的翻译字符串仍将从扩展包的原始语言文件中加载。