前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >laravel实现于语言包的完美切换方法

laravel实现于语言包的完美切换方法

作者头像
砸漏
发布2020-10-20 15:02:26
1.9K0
发布2020-10-20 15:02:26
举报
文章被收录于专栏:恩蓝脚本

需要引入:

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的中间件如下:

2、中间键创建完成后需要进行注册中间才能使用哦接下来我们进行注册language中间键进行注册,如果还是有不懂的小伙伴可以参考一下官网

http://laravelacademy.org/post/57.html,中间件详解,这块比较重要:

8在app下面找到Http/Kernel.php,编辑该文件 找到如下:

代码语言:javascript
复制
 protected $middlewareGroups = [
    'web' =  [
      \App\Http\Middleware\EncryptCookies::class,
      \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
      \Illuminate\Session\Middleware\StartSession::class,
      \Illuminate\View\Middleware\ShareErrorsFromSession::class,
      \App\Http\Middleware\VerifyCsrfToken::class,
      \App\Http\Middleware\Language::class, //语言包中间件注册。
    ],

3、接下来我们开始书写路由了:Route::get(‘demos’,’IndexController@ins’);

4、通过路由访问对应的控制器接下来我们创建一个控制器IndexController

思路:前端页面通过下拉菜单获取当前用户选择的语言包是英文还是简体。通过ajax请求到当前控制器,把通过setLocale进行设置,把语言包存入到session中进行返回。返回的同时进行刷新页面

代码语言:javascript
复制
use Illuminate\Support\Facades\Session;
use Illuminate\Support\Facades\App;
use Illuminate\Http\Response;
代码语言:javascript
复制
public function ins(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{
代码语言:javascript
复制
		//刷新后页面,再去获取语言包
      $rr = App::getLocale();
代码语言:javascript
复制
	//写入自己的逻辑存把信息返回到页面中区
      return view('welcome')- with('lan',$rr);
    }
  }

5、接下来我们开始编写前端的代码:在我们直接一welcome页面为例子:

代码语言:javascript
复制
<div class="container" 
      <div class="content" 
          <!--<div class="title" <a href="/demo/zh_cn" rel="external nofollow"  {{ trans('welcome.message') }}</a </div -- 
          <select οnchange="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/home/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 

中英文切换完成。我这边在做语言包数据切换时,在后台是直接切换中英数据库来实现数据的切换。这样看起来不是那么的乱。如果亲们还有什么好的方法一定留言

以上这篇laravel实现于语言包的完美切换方法就是小编分享给大家的全部内容了,希望能给大家一个参考。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档