Laravel通过语言文件和__()函数实现多语言,配置locale并创建对应翻译文件,使用路由切换语言并存入session,结合中间件自动设置,支持变量替换与复数形式处理。

Laravel 提供了强大且灵活的多语言与本地化支持,通过语言文件、翻译函数和区域设置切换,可以轻松实现网站的多语言功能。以下是具体实现步骤和最佳实践。
配置可用语言
在开始之前,先确定你的应用需要支持哪些语言。Laravel 的语言文件存放在 resources/lang 目录下,每个语言对应一个子目录,例如:
- resources/lang/zh/messages.php
- resources/lang/en/messages.php
你可以在 config/app.php 中设置默认语言:
'locale' => 'zh', 'fallback_locale' => 'en',创建语言文件
在对应语言目录中创建翻译文件,比如 messages.php:
resources/lang/zh/messages.php:
return [ 'welcome' => '欢迎使用我们的服务', 'login' => '登录', ];resources/lang/en/messages.php:
return [ 'welcome' => 'Welcome to our service', 'login' => 'Login', ];你可以按模块或页面创建多个文件,如 auth.php、pagination.php 等,Laravel 原生已包含部分常用语言包。
PrestaShop 开源网店系统是一款针对web2.0设计的全功能、跨平台的免费开源电子商务解决方案,自08年1.0版本发布,短短两年时间,发展迅速,全球已超过四万家网店采用Prestashop进行布署。Prestashop 开源网店系统基于Smarty引擎编程设计,模块化设计,扩展性强,能轻易实现多种语言,多种货币浏览交易,支持Paypal等几乎所有的支付手段,是外贸网站建站的佳选。Prest
在代码中使用翻译
Laravel 提供 __() 函数或 @lang 指令来获取翻译内容。
-
控制器中:
return view('home', ['title' => __('messages.welcome')]); -
Blade 模板中:
@lang('messages.welcome') 或 {{ __('messages.welcome') }} -
带变量的翻译:
定义: 'greeting' => '你好, :name'
使用: __('messages.greeting', ['name' => '张三'])
动态切换语言
用户可通过路由或按钮切换语言。常见做法是通过中间件或控制器设置当前语言。
示例:创建一个切换语言的路由:
Route::get('/lang/{locale}', function ($locale) { if (in_array($locale, ['zh', 'en'])) { session(['locale' => $locale]); app()->setLocale($locale); } return redirect()->back(); });然后在中间件或 AppServiceProvider 中读取 session 并设置语言:
// AppServiceProvider.php public function boot() { if (session()->has('locale')) { app()->setLocale(session('locale')); } }这样每次请求都会根据用户的 session 设置正确的语言环境。
基本上就这些。Laravel 的本地化机制简洁高效,配合合理的语言文件组织和路由设计,可以快速实现多语言网站。注意保持翻译键名一致,并考虑后期用工具导出导入管理翻译内容。不复杂但容易忽略细节,比如复数形式和日期格式本地化,可进一步使用 trans_choice 和 Carbon::setLocale() 处理。









