import{_ as s,o as a,c as l,V as n}from"./chunks/framework.b31a4d00.js";const B=JSON.parse('{"title":"@fesjs/plugin-locale","description":"","frontmatter":{},"headers":[],"relativePath":"reference/plugin/plugins/locale.md"}'),o={name:"reference/plugin/plugins/locale.md"},p=n(`
国际化插件,基于 Vue I18n,用于解决 i18n 问题。
在 package.json
中引入依赖:
{
"dependencies": {
"@fesjs/fes": "^3.0.0",
"@fesjs/plugin-locale": "^3.0.0"
}
}
Fes.js 约定如下目录,项目就拥有了 zh-CN
与 en-US
国际化语言切换:
src
├── locales
│ ├── zh-CN.js
│ └── en-US.js
└── pages
│ └── index.vue
└── app.js
多语言文件的命名规范:<lang>-<COUNTRY>.js
多语言文件的内容规范:键值组成的字面量,如下:
// src/locales/zh-CN.js
export default {
menu: {
interface: '接口',
},
overview: '概述',
i18n: {
internationalization: '国际化,基于',
achieve: '实现。',
ui: 'UI组件',
},
};
// src/locales/en-US.js
export default {
menu: {
interface: 'interface',
},
overview: 'Overview',
i18n: {
internationalization: 'internationalization,base on',
achieve: 'to achieve.',
ui: 'UI components',
},
};
想了解更多语言信息配置、匹配规则,请参考 Vue I18n 文档。
如果国际化内容较多,希望模块化配置,则可以这样:
src
├── locales
│ ├── zh-CN.js
│ └── en-US.js
| └── system
| ├── zh-CN.js
│ └── en-US.js
└── pages
│ └── index.vue
└── app.js
插件会把相同语言的配置合并在一起!
在执行 fes dev
或者 fes build
时,通过此配置生成运行时的代码,在配置文件.fes.js
中配置:
export default {
locale: {},
};
默认配置为:
export default {
locale: {
locale: 'zh-CN', // default locale
fallbackLocale: 'zh-CN', // set fallback locale
baseNavigator: true, // 开启浏览器语言检测
legacy: false, // 用户是否需要 Legacy API 模式
},
};
所有配置项如下:
类型:String
默认值:zh-CN
详情:当前的语言。
类型:String
默认值:zh-CN
详情:兜底的语言,如果当前语言找不到配置,则使用默认语言,需要保证默认语言配置文件存在。
类型:Boolean
默认值:true
详情:开启浏览器语言检测。
默认情况下,当前语言环境的识别按照:localStorage
中 fes_locale
值 > 浏览器检测 > default
设置的默认语言 > zh-CN
中文。
类型:Boolean
默认值:false
详情:用户是否需要 Legacy API 模式
暂无。
插件 API 通过 @fesjs/fes
导出:
import { locale } from '@fesjs/fes';
Object
Function
<lang>-<COUNTRY>
规范的名称。null
import { locale } from '@fesjs/fes';
locale.setLocale({ locale: 'en-US' });
Function
<lang>-<COUNTRY>
规范的名称。null
import { locale } from '@fesjs/fes';
locale.addLocale({ locale: 'ja-JP', messages: { test: 'テスト' } });
Function
en-US.js
文件。Array
import { locale } from '@fesjs/fes';
console.log(locale.getAllLocales());
// ["en-US", "id-ID", "ja-JP", "pt-BR", "zh-CN", "zh-TW"]
Composition API, 只能在 setup
函数中使用,更多细节参考 Vue I18n。 \b 举个 🌰:
<template>
<form>
<label>{{ t('language') }}</label>
</form>
<p>message: {{ t('hello') }}</p>
</template>
<script>
import { useI18n } from '@fesjs/fes'
export default {
setup() {
const { t } = useI18n()
// Something to do ...
return { ..., t }
}
}
</script>
useI18n()
返回结果是 Composer,提供类似 t
、n
、d
等转换函数,在模板中使用。