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 库的示例:

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

相关推荐
指针满天飞8 分钟前
同步、异步、Promise、then、async/await
前端·javascript·vue.js
Alang13 分钟前
记一次错误使用 useEffect 导致电脑差点“报废”
前端·react.js
牛奶31 分钟前
前端学AI:LangGraph学习-基础概念
前端·langchain·ai编程
welkin35 分钟前
算法区间合并问题
前端·算法
Mintopia42 分钟前
Three.js高效几何体创建指南:BufferGeometry深度解析
前端·javascript·three.js
ak啊1 小时前
Webpack Loader 执行机制
前端·webpack·源码
牛马喜喜1 小时前
如何从零实现一个todo list(1)
前端
牛马喜喜1 小时前
Vue编写一个自己的树形组件
前端
Mintopia1 小时前
vue3 element-plus 二次封装Drawer抽屉,关闭时添加二次对话,开箱即用
前端·javascript·vue.js
stanny1 小时前
Terminal里的ChatGPT:用80行代码实现带记忆的智能对话流
javascript