laravel实现于语言包的完美切换
2017-08-23 12:00
295 查看
需要引入:
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;
5、接下来我们开始编写前端的代码:在我们直接一welcome页面为例子:
<div class="container">
<div class="content">
<!--<div class="title"><a href="/demo/zh_cn">{{ trans('welcome.message') }}</a></div>-->
<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/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>
中英文切换完成。我这边在做语言包数据切换时,在后台是直接切换中英数据库来实现数据的切换。这样看起来不是那么的乱。如果亲们还有什么好的方法一定留言
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">{{ trans('welcome.message') }}</a></div>-->
<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/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>
中英文切换完成。我这边在做语言包数据切换时,在后台是直接切换中英数据库来实现数据的切换。这样看起来不是那么的乱。如果亲们还有什么好的方法一定留言
相关文章推荐
- javascript回车完美实现tab切换功能
- 仿御泥坊 完美实现电商类项目底部选项卡切换Fragment页面
- 完美实现tabsheet中融合窗体,不重复创建,并自动切换到已经创建的sheet
- IOS APP 国际化 程序内切换语言实现 不重新启动系统(支持项目中stroyboard 、xib 混用。完美解决方案)
- 完美实现js选项卡切换效果(二)
- WebView视屏全屏切换,完美实现
- Yii2.0实现语言包切换功能
- 完美实现js选项卡切换效果(一)
- js 读取json语言包,实现页面的双语切换
- 完美JQuery图片切换效果的简单实现
- 完美JQuery图片切换效果的简单实现
- javascript 回车实现 tab 切换功能完美解决
- 完美兼容各大浏览器的jQuery插件实现图片切换特效
- IOS APP 国际化 程序内切换语言实现 不重新启动系统(支持项目中stroyboard 、xib 混用。完美解决方案)
- javascript回车完美实现tab切换功能
- javascript回车完美实现tab切换功能
- 【转】VBS脚本 实现"无线网络连接"与"本地连接"的网卡禁用启用完美切换(优化版)
- 完美兼容各大浏览器的jQuery插件实现图片切换特效
- 【iphone游戏开发】Iphone游戏开发之五:游戏场景切换,点阵字的实现和Hiero工具的利用
- Laravel手动分页实现方法详解