本地化

    所有的语言文件都返回一个键值对。 例子:

    1. <?php
    2. return [
    3. 'welcome' => 'Welcome to our application'
    4. ];

    应用的默认语言保存在 config/app.php 配置文件中。你可以根据需要修改当前设置,还可以使用 App Facade 的 setLocale 方法动态地更改当前语言:

    1. Route::get('welcome/{locale}', function ($locale) {
    2. //
    3. });

    你也可以设置『备用语言』,它将会在当前语言不包含给定的翻译字符串时被使用。像默认语言一样,备用语言也可以在 config/app.php 配置文件设置:

    1. 'fallback_locale' => 'en',

    确定当前语言环境

    你可以使用 App Facade 的 getLocaleisLocale 方法确定当前的区域设置或者检查语言环境是否为给定值:

    1. $locale = App::getLocale();
    2. if (App::isLocale('en')) {
    3. //

    通常,翻译字符串存放在 resources/lang 目录下的文件里。在此目录中,但凡应用支持的语言都应该有一个对应的子目录:

    所有语言文件只返回键值对数组,例如:

    1. <?php
    2. // resources/lang/en/messages.php
    3. return [
    4. 'welcome' => 'Welcome to our application'
    5. ];

    对于有大量翻译需求的应用,如果每一条翻译语句都使用『短键』来定义,那么当你在视图中尝试去引用这些『短键』的时候,很容易变得混乱。因此, Laravel 也提供支持使用字符串的『默认』翻译作为关键字来定义翻译字符串。

    使用翻译字符串作为键的翻译文件以 JSON 文件存储在 resources/lang 目录中。例如,如果你的应用中有西班牙语翻译,你应该新建一个 resources/lang/es.json 文件:

    1. "I love programming.": "Me encanta programar."
    2. }

    你可以使用辅助函数 从语言文件中检索, 方法接受翻译字符串的文件名和键值作为其第一个参数。例如,让我们检索 resources/lang/messages.php 语言文件中的 welcome 翻译字符串:

    1. echo __('messages.welcome');
    2. echo __('I love programming.');

    如果使用 Blade 模版引擎,可以在视图文件中使用 {{ }} 语法或者使用 @lang 指令来打印翻译字符串:

    1. @lang('messages.welcome')

    如果指定的翻译字符串不存在, 方法则会简单地返回指定的翻译字符串键名。所以,如果上述示例中的翻译字符串键不存在,那么 方法则会返回 messages.welcome

    如果需要,也可以在翻译字符串中定义占位符。所有的占位符都有一个前缀 : 。例如,你可以使用持有人名称定义欢迎消息:

    1. echo __('messages.welcome', ['name' => 'dayle']);

    如果你的占位符中包含了首字母大写或者全体大写,翻译过来的内容也会做相应的处理:

    1. 'welcome' => 'Welcome, :NAME', // Welcome, DAYLE
    2. 'goodbye' => 'Goodbye, :Name', // Goodbye, Dayle

    复数是个复杂的问题,不同语言对于复数有不同的规则。使用管道符 | ,可以区分字符串的单复数形式:

    1. 'apples' => 'There is one apple|There are many apples',

    你甚至可以创建更复杂的复数规则,为多个数字范围指定翻译字符串:

    1. 'apples' => '{0} There are none|[1,19] There are some|[20,*] There are many',

    在定义具有复数选项的翻译字符串之后,你可以使用 trans_choice 方法来检索给定『数量』的内容。在这个例子中,设置『总数』为 10 ,符合数量范围 1 至 19 ,所以会得到 There are some 这条复数语句:

    你也可以在复数字符串中插入占位符, trans_choice 方法第三个参数所传递数组将会替换占位符。

    1. 'minutes_ago' => '{1} :value minute ago|[2,*] :value minutes ago',
    2. echo trans_choice('time.minutes_ago', 5, ['value' => 5]);

    部分扩展包可能会附带自己的语言文件。你可以通过在 resources/lang/vendor/{package}/{locale} 放置文件来重写它们,而不是直接修改扩展包的核心文件。

    本文章首发在 LearnKu.com 网站上。