laravel语言包的切换

2018-08-24  本文已影响0人  云窗96

引入:
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

上一篇 下一篇

猜你喜欢

热点阅读