本地化
简介
默认情况下,Laravel 应用程序框架不包含 lang
目录。如果你想自定义 Laravel 的语言文件,可以通过 lang:publish
Artisan 命令发布它们。
Laravel 的本地化功能提供了一种方便的方法来检索各种语言的字符串,从而使你可以轻松地在应用程序中支持多种语言。
Laravel 提供了两种管理翻译字符串的方法。首先,语言字符串可以存储在 lang
目录里的文件中。在此目录中,可能存在应用程序支持的每种语言的子目录。这是 Laravel 用于管理内置 Laravel 功能(例如验证错误消息)的翻译字符串的方法:
/lang
/en
messages.php
/es
messages.php
或者,可以在 lang
目录中放置的 JSON 文件中定义翻译字符串。采用这种方法时,应用程序支持的每种语言在此目录中都会有一个对应的 JSON 文件。对于具有大量可翻译字符串的应用,建议使用此方法:
/lang
en.json
es.json
我们将在本文档中讨论每种管理翻译字符串的方法。
发布语言文件
默认情况下,Laravel 应用程序框架不包含 lang
目录。如果你想自定义 Laravel 的语言文件或创建自己的语言文件,则应通过 lang:publish
Artisan 命令构建 lang
目录。 lang:publish
命令将在应用程序中创建 lang
目录,并发布 Laravel 使用的默认语言文件集:
php artisan lang:publish
配置语言环境
应用程序的默认语言存储在 config/app.php
配置文件的 locale
配置选项中。你可以随意修改此值以适合你的应用程序的需求。
你可以使用 App
Facade 提供的 setLocale
方法,在运行时通过单个 HTTP 请求修改默认语言:
use Illuminate\Support\Facades\App;
Route::get('/greeting/{locale}', function (string $locale) {
if (! in_array($locale, ['en', 'es', 'fr'])) {
abort(400);
}
App::setLocale($locale);
// ...
});
你可以配置一个 「备用语言」,当当前语言不包含给定的翻译字符串时,将使用该语言。和默认语言一样,备用语言也是在 config/app.php 配置文件中配置的。
'fallback_locale' => 'en',
确定当前的语言环境
你可以使用 currentLocale
和 isLocale
方法来确定当前的 locale
或检查 locale
是否是一个给定值。
use Illuminate\Support\Facades\App;
$locale = App::currentLocale();
if (App::isLocale('en')) {
// ...
}
多语种
你可以使用 Laravel 的「pluralizer」来使用英语以外的语言,Eloquent 和框架的其他部分使用它来将单数字字符串转为复数字符串。这可以通过调用应用程序服务提供的 boot
方法中的 useLanguage
方法来实现。复数器目前支持的语言有 法语
, 挪威语
, 葡萄牙语
, 西班牙语
, 土耳其语
:
use Illuminate\Support\Pluralizer;
/**
* 引导任何应用程序服务。
*/
public function boot(): void
{
Pluralizer::useLanguage('spanish');
// ...
}
如果你想自定义 pluralizer 的语言,则应该明确定义 Elquent 模型的 表名。
定义翻译字符串
使用短键
通常,翻译字符串存储在 lang
目录中的文件中。在这个目录中,应用程序支持的每种语言都应该有一个子目录。这是 Laravel 用于管理内置 Laravel 功能(如验证错误消息)的翻译字符串的方法:
/lang
/en
messages.php
/es
messages.php
所有的语言文件都会返回一个键值对数组。比如下方这个例子:
<?php
// lang/en/messages.php
return [
'welcome' => 'Welcome to our application!',
];
对于不同地区的语言,应根据 ISO 15897 命名语言目录。例如,英式英语应使用「en_GB」而不是 「en_gb」。
使用翻译字符串作为键
对于具有大量可翻译字符串的应用程序,在视图中引用键时,使用「短键」定义每个字符串可能会令人困惑,并且为应用程序支持的每个翻译字符串不断发明键会很麻烦。
出于这个原因,Laravel 还支持使用字符串的「默认」翻译作为键来定义翻译字符串。使用翻译字符串作为键的翻译文件作为 JSON 文件存储在 lang
目录中。例如,如果你的应用程序有西班牙语翻译,你应该创建一个 lang/es.json
文件:
{
"I love programming.": "Me encanta programar."
}
键 / 文件冲突
你不应该定义和其他翻译文件的文件名存在冲突的键。例如,在 nl/action.php
文件存在,但 nl.json
文件不存在时,对 NL
语言翻译 __('Action')
会导致翻译器返回 nl/action.php
文件的全部内容。