经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
laravel实现于语言包的完美切换方法
来源:jb51  时间:2019/9/30 8:49:45  对本文有异议

需要引入:

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,编辑该文件 找到如下:

  1. protected $middlewareGroups = [
  2. 'web' => [
  3. \App\Http\Middleware\EncryptCookies::class,
  4. \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
  5. \Illuminate\Session\Middleware\StartSession::class,
  6. \Illuminate\View\Middleware\ShareErrorsFromSession::class,
  7. \App\Http\Middleware\VerifyCsrfToken::class,
  8. \App\Http\Middleware\Language::class, //语言包中间件注册。
  9. ],

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

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

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

  1. use Illuminate\Support\Facades\Session;
  2. use Illuminate\Support\Facades\App;
  3. use Illuminate\Http\Response;
  1. public function ins(Request $request){
  2. if($request->ajax()){
  3. $data = $request->all();
  4. App::setLocale($data['language']);
  5. $res = $request->session()->put('language',$data['language']);
  6. return $this->returnCode(200,'',$res);
  7. }else{
  1. //刷新后页面,再去获取语言包
  2. $rr = App::getLocale();
  1. //写入自己的逻辑存把信息返回到页面中区
  2. return view('welcome')->with('lan',$rr);
  3. }
  4. }

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

  1. <div class="container">
  2. <div class="content">
  3. <!--<div class="title"><a href="/demo/zh_cn" rel="external nofollow" >{{ trans('welcome.message') }}</a></div>-->
  4. <select οnchange="changelanguage(this.value)">
  5. <option value="en">
  6. @if(App::getLocale() =='en')
  7. selected
  8. @else
  9. @endif
  10. English
  11. </option>
  12. <option value='zh_cn'@if(App::getLocale() == 'zh_cn') selected @else @endif>简体中文</option>>
  13. <div>{{trans('welcome.message')}}{{$lan}}</div>
  14. </select>
  15. </div>
  16. <script src="{{asset('public/home/js/jquery.min.js')}}"></script>
  17. <script>
  18. function changelanguage(val){
  19. $.ajax({
  20. type :'get',
  21. url :'demos',
  22. data:{
  23. language :val
  24. },
  25. dataType :'json',
  26. success:function(res){
  27. if(res){
  28. window.location.reload();
  29. }
  30. }
  31. })
  32. }
  33. </script>
  34. </body>

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

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号