前言
本文主要给大家介绍了关于Laravel本地化模块的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍吧。
本文是基于Laravel 5.4版本的本地化模块代码进行分析书写;
模块组成
下图展示了本地化模块各个文件的关系,并进行简要说明;
配置说明
在config配置目录下和本模块有关的参数只有app.php文件中的locale和fallback_locale;
locale表示默认本地化语言是什么,这样会优先从该语言资源目录中获取翻译(转换)内容;
如果locale表示的语言不存在,则使用fallback_locale这个备用语言;
笔者的locale是zh_CN,fallback_locale是en;
功能介绍
全局的语言资源目录在项目的resources/lang下,每个子目录分别以语言为名,比如en、zh_CN等;
另外一些子目录是命名空间为名,是对第三方加载库资源文件的补充替换;
有可能还存在en.json、zh_CN这类Json文件,项目有时候会从Json文件读取数据,这些数据均来自于这个已存在的Json文件;
翻译全局语言资源
笔者的语言资源根目录resources/lang下有zh_CN/validation.php,内容如下
<?php return [ 'accepted' => ':attribute 必须接受。', 'active_url' => ':attribute 不是一个有效的网址。', 'after' => ':attribute 必须是一个在 :date 之后的日期。', ...... ];
通过调用代码
app('translator')->trans('validation.accepted', ['attribute' => '用户名'])
或者全局帮助函数trans
trans('validation.accepted', ['attribute' => '用户名'])
输出 "用户名 必须接受。";
调用过程如下:
$namespace = '*', $group = 'validation', $item = 'accepted'
);namespace为*,表示在全局命名空间下;group,组,其实就是文件名,一个文件为一组;item是元素的意思;$this->loaded[$namespace][$group][$locale] = $lines;
Arr::get
方法从$this->loaded[$namespace][$group][$locale]
中获取元素值:attribute 必须接受。;此时,参数数组为不空,循环替换,得到结果"用户名 必须接受。";翻译带命名空间的语言资源
笔者在语言资源根目录resource/lang下,创建vendor/Faker/Provider/zh_CN/Internet.php文件,内容如下:
<?php return [ 'message' => 'hello, Faker/Provider', ...... ];
同时,手动在Translator中注册第三方插件(也就是带命名空间)的资源根目录位置;
app('translator')->addNamespace('Faker/Provider', base_path('vendor/xx/resource/lang'))
现在,获取带命名空间的资源;
trans('Faker/Provider::Internet.message');
输出 'hello, Faker/Provider';