引入:
use Illuminate\Support\Facades\Session;
use Illuminate\Support\Facades\App;
App::getLocale();获取当前语言
App::setLocale();设置语言配置文件
语言配置文件config/app.php
locale 是默认语言,fallback_locale为备用语言
语言字符串存放在resources/lang目录中,Blade模板引擎打印语言行{{ trans('messages.welcome') }}
思路是把当前的语言设定存在Session里头,然后再写个Middleware去截Http请求,在截住的请求里用Session里的语言设定值来设Locale。
1.创建中间件并注册
在Mideleware中创建一个名为language.php的中间件,并进行中间件的注册,如下:
public function handle($request, Closure $next)
{
if($request->session()->has('language')){
App::setLocale($request->session()->get('language'));
}else{
App::setLocale(Config::get('app.fallback_locale'));
}
return $next($request);
}
2.思路:前端页面通过下拉菜单获取当前用户选择的语言包是英文还是简体。通过ajax请求到当前控制器,把通过setLocale进行设置,把语言包存入到session中进行返回。返回的同时进行刷新页面
3.控制器的编写
public function index(Request $request){
if($request->ajax()){
$data = $request->all();
App::setLocale($data['language']);
$res = $request->session()->put('language',$data['language']);
return $this->returnCode(200,'',$res);
}else{
//刷新后页面,再去获取语言包
$rr = App::getLocale();
//写入自己的逻辑存把信息返回到页面中区
return view('welcome')->with('lan',$rr);
}
}
4.前端页面的编写,welcome页面为例子:
<div class="container">
<div class="content">
<select onchange="changelanguage(this.value)">
<option value="en">
@if(App::getLocale() =='en')
selected
@else
@endif
English
</option>
<option value='zh_cn'@if(App::getLocale() == 'zh_cn') selected @else @endif>简体中文</option>>
<div>{{trans('welcome.message')}}{{$lan}}</div>
</select>
</div>
<script src="{{asset('public/js/jquery.min.js')}}"></script>
<script>
function changelanguage(val){
$.ajax({
type :'get',
url :'demos',
data:{
language :val
},
dataType :'json',
success:function(res){
if(res){
window.location.reload();
}
}
})
}
</script>
</body>
参考:https://blog.csdn.net/chen529834149/article/details/77504335
网友评论