美文网首页
laravel语言包的切换

laravel语言包的切换

作者: 云窗96 | 来源:发表于2018-08-24 15:01 被阅读0次

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

    相关文章

      网友评论

          本文标题:laravel语言包的切换

          本文链接:https://www.haomeiwen.com/subject/dppfbftx.html