php – 如何在Laravel中为两种语言的路由生成URL
发布时间:2020-12-14 19:37:29 所属栏目:大数据 来源:网络整理
导读:基于这个 thread我试图为我的网站实现额外的英语,默认是法语,不使用任何前缀,所以像www.website.com和切换到英语将是www.website.com/en/,我’ d喜欢分别使用联系页面的网址,如www.website.com/en/contact和www.website.com/contact,分别为英文版和法文版.
基于这个
thread我试图为我的网站实现额外的英语,默认是法语,不使用任何前缀,所以像www.website.com和切换到英语将是www.website.com/en/,我’ d喜欢分别使用联系页面的网址,如www.website.com/en/contact和www.website.com/contact,分别为英文版和法文版.
我目前的路线.php if (Request::segment(1) == 'en') { App::setLocale(Request::segment(1)); Config::set('app.locale_prefix',Request::segment(1)); } else { App::setLocale('fr'); Config::set('app.locale_prefix',''); } Route::group(array('prefix' => Config::get('app.locale_prefix')),function() { Route::get( '/',function () { //return "main page - ".App::getLocale(); return view('index'); } ); Route::get( '/contact/',function () { return view('contact'); }); }); 我的头文件,其中切换语言的标志图标是 @if (Lang::locale() == 'fr') <a href="{{ url('/en/' . Request::segment(1)) }}"><img src="{{asset('images/GB.png')}}"></a> @elseif (strcasecmp(Request::segment(1),'en') == 0 && Request::segment(2) != NULL) <a href="{{ url( Request::segment(2)) }}"><img src="{{asset('images/FR.png')}}"></a> @else <a href="{{ url( '/') }}"><img src="{{asset('images/FR.png')}}"></a> @endif 以及我生成网址的方式 <a class="block-title" href="{{ (strcasecmp(Request::route()->getPrefix(),'/en') == 0) ? url('en/contact') : url('/contact') }}">CONTACT</a> 我想知道一种更简洁的方法来生成这些以及我如何获得英文主页面网址www.website.com/en/而不是www.website.com/en 非常感谢 ! 解决方法
生成URL的最佳方法是:
首先,给你的路线命名: //this route is called 'contact_route' Route::get('/contact/',['as' => 'contact_route',function () { return view('contact'); }]); 路由是使用语言环境和前缀动态构建的,但是一旦定义了路由并且您给它命名,就可以使用route helper with:route(‘contact_route’)为路由创建URL 你的例子将成为: <a class="block-title" href="{{ route('contact_route') }}">CONTACT</a> 您可以在docs中了解更多命名路线 对于尾部斜杠,默认的Laravel .htaccess文件,使用以下规则删除网址末尾的所有斜杠: RewriteRule ^(.*)/$$1 [L,R=301] 它捕获从斜杠/ $开始^到结尾的所有(.*)并用捕获的内容替换它.因此,如果要添加尾部斜杠,可能应编辑.htaccess文件 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |