## 多语言
在`FastAdmin`应用插件中支持多语言切换,如果我们在开发过程中需要使用到多语言展示,可以按以下方法进行修改。
## 语言包文件
多语言目录为`lang`,其中存放以语言标识命名的语言包。
~~~bash
addons/mydemo/lang/zh-cn.php
addons/mydemo/lang/en.php
...
~~~
## 多语言输出
我们在插件开发过程中可以使用多语言功能来自动输出相应的文字
### 视图模板
如果我们需要在视图模板中实现多语言输出替换,可以使用如下的方式,例如:
~~~bash
<a href="/">{:__('Home')}</a>
<a href="/">{:__('This is %s,base on %s', 'FastAdmin', 'ThinkPHP5')}</a>
~~~
此时我们需要在对应的多语言文件定义语言包,例如:
~~~php
<?php
return [
'Home' => '首页',
'This is %s,base on %s' => '这是%s,基于%s'
];
~~~
则在中文语言环境下展示效果为
~~~xml
<a href="/">首页</a>
<a href="/">这是FastAdmin,基于ThinkPHP5</a>
~~~
如果未定义语言包,默认会展示为
~~~xml
<a href="/">Home</a>
<a href="/">This is FastAdmin,base on ThinkPHP5</a>
~~~
### 控制器
如果我们需要在控制器中使用多语言,我们仍然可以使用`__`方法来实现,例如:
~~~bash
$title = __('Home');
$description = __('This is %s,base on %s', 'FastAdmin', 'ThinkPHP5');
~~~
此时`$title`和`$descripttion`的值为自动进行多语言转换后的值。
## 切换多语言
当我们有多个语言世时,如果需要在前台切换多语言,我们可以通过以下几种方式进行切换
### URL参数切换
我们可以通过传递`lang`参数来强制使用指定语言包,例如
~~~javascript
http://www.example.com/addons/mydemo/?lang=en
http://www.example.com/addons/mydemo/?lang=zh-cn
~~~
### Cookie变量切换
很多时候我们切换一次多语言后,后续请求的页面也需要保持切换后的指定语言来显示,此时我们就需要使用到`cookie`来存储语言标识。
我们可以通过在PHP中或JS操作`think_var`这个`cookie`值来切换多语言。
~~~javascript
//php
setcookie('think_var', 'en');
//js
function setCookie(name,value,seconds) {
var expires = "";
if (seconds) {
var date = new Date();
date.setTime(date.getTime() + (seconds*1000));
expires = "; expires=" + date.toUTCString();
}
document.cookie = name + "=" + (value || "") + expires + "; path=/";
}
setCookie('think_var', 'en');
~~~
## 常见问题
1. 语言包定义是不区分大小写的
2. 默认多语言会自适应用户当前的浏览环境,如果需要关闭自适应,请修改`application/config.php`中的`lang_switch_on`修改为`false`