时间:2021-05-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,编辑该文件 找到如下:
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中进行返回。返回的同时进行刷新页面
use Illuminate\Support\Facades\Session;use Illuminate\Support\Facades\App;use Illuminate\Http\Response;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{ //刷新后页面,再去获取语言包 $rr = App::getLocale(); //写入自己的逻辑存把信息返回到页面中区 return view('welcome')->with('lan',$rr); } }5、接下来我们开始编写前端的代码:在我们直接一welcome页面为例子:
<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实现于语言包的完美切换方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了laravel框架语言包拓展实现方法。分享给大家供大家参考,具体如下:laravel使用make:auth生成用户认证,登录表单是英文版本的,打开
可能有不少软件作者因为语言包的问题而纠结,因为易语言没自带导入语言包的命令,所以只能用最普通的方式来导入语言包1、新建一个“易语言”窗口程序2、然后在桌面创建两
本文以实例讲述了CodeIgniter采用config控制的多语言实现根据浏览器语言自动转换功能,对于网站开发来说非常实用。具体操作方法如下:语言包文件如下:a
前言项目需要支持多语言,我们需要提取出项目中使用的静态文本,使用语言包进行管理,当切换语言设置的时候,可以自动切换整个项目的文字显示。发现Vue项目中有对应
Chinese语言包安装首先需要给Ubuntu16.04安装Chinese语言包支持。如上图点击其中的Install/RemoveLanguages…,这个对话