使用 Laravel 翻译加载器在 JavaScript 中使用 Laravel 翻译

发布于 作者

Using Laravel translations in Javascript with the Laravel Translations Loader image

您是否曾经想过在前端代码中使用与后端相同的 Laravel 翻译?

Laravel 翻译加载器 是一个 webpack 加载器,它使您能够将 Laravel 翻译加载到您的 JavaScript 包中。

该包不会执行 HTTP 请求来获取翻译,而是参与资产编译过程,并将您的 PHP 翻译文件(JSON 和 PHP)转换为 JSON 对象,以便您根据需要使用它。

它与 vue-i18n 等包开箱即用,或者可以对流行的 i18next 包进行一些配置调整。

显示代码

第一步是使用 NPM 或 Yarn 安装该包。

npm install @kirschbaum-development/laravel-translations-loader --save
yarn add @kirschbaum-development/laravel-translations-loader --save

或者,使用 Yarn。

npm install @kirschbaum-development/laravel-translations-loader --save

基本上,在您的 JavaScript 文件中,您只需要包含以下代码行来导入您的语言包。

import languageBundle from
'@kirschbaum-development/laravel-translations-loader!@kirschbaum-development/laravel-translations-loader';

这将加载并解析所有您的语言文件,包括 PHP 和 JSON 翻译。languageBundle 将类似于以下内容

{
"en": {
"auth": {
"failed": "These credentials do not match our records."
}
},
"es": {
"auth": {
"failed": "Estas credenciales no coinciden con nuestros registros."
}
}
}

以及您翻译文件夹中的所有其他翻译。

您可以选择仅加载 PHP 或 JSON 翻译文件,也可以在语言键和某些包所需的实际翻译之间添加命名空间。您可以在项目的 自述文件 上查看不同的加载选项。如果您遇到任何问题或有任何建议,请提交 问题

使用 vue-i18n 的示例

请注意,您可以直接将 languageBundle 对象作为参数传递给 VueI18n 构造函数。

import languageBundle from '@kirschbaum-development/laravel-translations-loader!@kirschbaum-development/laravel-translations-loader';
import VueI18n from 'vue-i18n';
Vue.use(VueI18n);
const i18n = new VueI18n({
locale: window.Locale,
messages: languageBundle,
})

在任何 vue 组件中,您都可以直接使用 $t 函数,如下例所示

<template>
<span>{{ $t('auth.failed') }}</span>
<!-- this will output the same as {{ trans('auth.failed') }} using Laravel -->
</template>
Luis Dalmolin photo

Luis 是 Kirschbaum 的高级开发人员,拥有超过 10 年的复杂应用程序架构经验,并且从 Laravel 4 的早期就开始使用 Laravel。

除了 PHP 和 Laravel,Luis 还精通 VueJS/Javascript 和所有与 DevOps 相关的技术。他喜欢使用开源软件,并为社区贡献了许多开源项目。

Luis 在 Feevale 大学教授 AngularJS 课程,他也是在那里获得了互联网系统专业的学位,他还将 Dayle Rees 的 Laravel 书籍 “Code Bright” 翻译成了葡萄牙语。

归档于
Cube

Laravel 新闻稿

加入 40,000 多名其他开发人员,绝不错过新的技巧、教程等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和本地和生产环境的即时反馈进行测试。

Tinkerwell
No Compromises logo

No Compromises

Joel 和 Aaron 是 No Compromises 播客的两名经验丰富的开发人员,他们现在可以为您的 Laravel 项目提供服务。 ⬧ 固定费率为每月 7500 美元。 ⬧ 没有漫长的销售流程。 ⬧ 没有合同。 ⬧ 100% 返款保证。

No Compromises
Kirschbaum logo

Kirschbaum

提供创新和稳定性,确保您的 Web 应用程序成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel?立即进行自动 Laravel 升级和代码现代化,以保持应用程序的新鲜度。

Shift
Bacancy logo

Bacancy

为您的项目配备经验丰富的 Laravel 开发人员,拥有 4-6 年的经验,每月仅需 2500 美元。获得 160 小时的专业知识和 15 天的免费试用。立即安排通话!

Bacancy
Lucky Media logo

Lucky Media

现在就来试试 Lucky - 理想的 Laravel 开发选择,拥有超过 10 年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 电子商务。一个开源包,它将现代无头电子商务功能的强大功能带到 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 职位网站

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动工具包

SaaSykit 是一个 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、漂亮的结帐、管理面板、用户仪表盘、身份验证、现成的组件、统计数据、博客、文档等。

SaaSykit:Laravel SaaS 启动工具包
Rector logo

Rector

您无缝升级 Laravel 的合作伙伴,降低成本,加快创新,助力企业成功

Rector
MongoDB logo

MongoDB

利用 MongoDB 和 Laravel 的强大集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务性、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解 MongoDB 的灵活、现代数据库如何改变您的 Laravel 应用程序。

MongoDB

最新内容

查看全部 →
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

将 Swagger UI 添加到您的 Laravel 应用程序

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel 提示构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的站点搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包为您的 Laravel 应用程序添加评论

阅读文章