Univer
Univer Sheet
开始使用
国际化

国际化

使用预设语言包

0.1.13 版本后,Univer 不再内置任何语言包,所有语言包均由插件提供。如果你发现手动引入插件的语言包过于繁琐,我们还提供了一个构建工具插件,用于自动引入插件所需的语言包。请参考 使用 Univer 插件 获取更多信息。

如需手动添加语言包,你可以参考以下示例,根据需要引入对应的语言包并组装成对象传入 Univer 实例:

import { LocaleType, Tools } from '@univerjs/core';
import DesignZhCN from '@univerjs/design/locale/zh-CN';
import UIZhCN from '@univerjs/ui/locale/zh-CN';
import DocsUIZhCN from '@univerjs/docs-ui/locale/zh-CN';
import SheetsZhCN from '@univerjs/sheets/locale/zh-CN';
import SheetsUIZhCN from '@univerjs/sheets-ui/locale/zh-CN';
import SheetsFormulaUIZhCN from '@univerjs/sheets-formula-ui/locale/zh-CN';
 
const univer = new Univer({
  theme: defaultTheme,
  locale: LocaleType.ZH_CN,
  locales: {
    [LocaleType.ZH_CN]: Tools.deepMerge(
      SheetsZhCN,
      DocsUIZhCN,
      SheetsUIZhCN,
      SheetsFormulaUIZhCN,
      UIZhCN,
      DesignZhCN,
    ),
  },
});

Univer 目前内置了以下预设语言包:

  • zh-CN:简体中文
  • en-US:英文
  • ru-RU:俄文

需要注意的是,由于 Webpack 4 并不支持 package.json 的 exports 字段,因此你可能会需要修改引入语言包的路径。

- import DesignZhCN from '@univerjs/design/locale/zh-CN';
+ import DesignZhCN from '@univerjs/design/lib/locale/zh-CN.json'

如果你使用了 TypeScript,也需要确认是否在 tsconfig.json 中配置了 resolveJsonModule 选项。

{
  "compilerOptions": {
+    "resolveJsonModule": true
  }
}

使用自定义语言包

Univer 也支持自定义语言包,你可以根据需要自行组装语言包对象并传入 Univer 实例。可供参考的预设语言包一般存放在 <rootDir>/packages/<PLUGIN_NAME>/locale 目录下。

const univer = new Univer({
  theme: defaultTheme,
  locale: 'es-ES',
  locales: {
    'es-ES': {
      shortcut: {
        undo: 'Deshacer',
        redo: 'Rehacer',
      }
    },
  },
});

贡献语言包

Univer OSS 是一个充满包容性的开源项目,我们欢迎来自五湖四海的开发者为 Univer 添加或者改进语言包。如果你有兴趣为 Univer 贡献语言包,请参考 贡献指南


Copyright © 2021-2024 DreamNum Co,Ltd. All Rights Reserved.