WXT浏览器插件开发中文教程(20)----I18n国际化

前言

大家好,我是倔强青铜三 。是一名热情的软件工程师,我热衷于分享和传播IT技术,致力于通过我的知识和技能推动技术交流与创新,欢迎关注我,微信公众号:倔强青铜三。欢迎点赞、收藏、关注,一键三连!!!

I18n

Chrome 文档Firefox 文档

本页面讨论了如何使用原生的 browser.i18n API 设置国际化,并提到了一些替代方案,如果你希望使用其他工具。

使用方法

  1. 在清单文件中添加 default_locale

    ts 复制代码
    export default defineConfig({
      manifest: {
        default_locale: 'en',
      },
    });
  2. public/ 目录下创建 messages.json 文件:

    html 复制代码
    📂 {srcDir}/
       📂 public/
          📂 _locales/
             📂 en/
                📄 messages.json
             📂 de/
                📄 messages.json
             📂 ko/
                📄 messages.json
    json 复制代码
    // public/_locales/en/messages.json
    {
      "helloWorld": {
        "message": "Hello world!",
      },
    }
  3. 获取翻译:

    ts 复制代码
    browser.i18n.getMessage('helloWorld');
  4. 可选:为扩展程序的名称和描述添加翻译:

json 复制代码
{
  "extName": {
    "message": "..."
  },
  "extDescription": {
    "message": "..."
  },
  "helloWorld": {
    "message": "Hello world!"
  }
}
ts 复制代码
export default defineConfig({
  manifest: {
    name: '__MSG_extName__',
    description: '__MSG_extDescription__',
    default_locale: 'en',
  },
});

替代方案

原生 API 功能较少,因此你可能希望使用第三方 NPM 包,例如 i18nextreact-i18nvue-i18n 等。

然而,建议你坚持使用原生 API(或者基于原生 API 的包,例如 @wxt-dev/i18n),因为:

  • 它们可以在清单文件和 CSS 文件中本地化文本
  • 翻译是同步加载的
  • 翻译不会多次打包,保持扩展程序体积小
  • 零配置

然而,原生 API 及其基础上的任何包都有一个主要缺点:

  • 无法在不更改浏览器/系统语言的情况下更改语言

以下是一些设置第三方 i18n 库的示例:

最后感谢阅读!欢迎关注我,微信公众号倔强青铜三。欢迎点赞收藏关注,一键三连!!!

相关推荐
无巧不成书02181 小时前
Windows PowerShell执行策略详解:从npm报错到完美解决
前端·windows·npm·powershell执行策略·执行策略·npm.ps1·脚本报错
Z兽兽8 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang8 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda9 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06269 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~9 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle10 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界10 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser11 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码203511 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos