wodax-umi-plugin-locale

1.0.1 • Public • Published

umi-plugin-locale

i18n plugin for umi.


Suggest to use together with umi-plugin-react, see our website umi-plugin-react for more.


配置

.umirc.js

export default {
  plugins: [
    [
      'umi-plugin-react',
      {
        locale: {
          default: 'zh-CN', //默认语言 zh-CN
          baseNavigator: true, // 为true时,用navigator.language的值作为默认语言
          antd: true // 是否启用antd的<LocaleProvider />
        }
      }
    ]
  ]
};

Other: You can setDefaultLocal in src/app.js

export const locale = {
  default: 'en-US', //默认语言 zh-CN
};

目录及约定

.
├── dist/                          
├── mock/                         
└── src/                          
    ├── layouts/index.js          
    ├── pages/                    
    └── locales               // 多语言文件存放目录,里面的文件会被umi自动读取
        ├── zh-CN.js
        └── en-US.js               
├── .umirc.js                     
├── .env                          
└── package.json

如果.umirc.js里配置了singular: truelocales要改成locale

多语言文件约定

多语言文件的命名规范:<lang>-<COUNTRY>.js

多语言文件的内容规范:键-值组成的字面量,如下:

zh-CN.js

export default {
  WELCOME_TO_UMI_WORLD: '{name},欢迎光临umi的世界',
}

en-US.js

export default {
  WELCOME_TO_UMI_WORLD: '{name}, welcome to umi\'s world',
}

扩展API

使用本插件后,你可以从 umi-plugin-locale 引入国际化相关的 API,获得关于多语言功能在编程上的便利。

import { formatMessage, setLocale, getLocale, FormattedMessage } from 'umi-plugin-locale';
 
// 获取指定文字的多语言版本
const formatedText = formatMessage({
  id: 'WELCOME_TO_UMI_WORLD'
}, {
  name: '小伙子',
});
 
console.log(formatedText === '小伙子,欢迎光临umi的世界');
 
// 设置为 en-US
setLocale('en-US');
 
// 获取当前语言
console.log(getLocale() === 'en-US');
 
 
// 渲染一个文字标签
function Example() {
  return <FormattedMessage id="WELCOME_TO_UMI_WORLD" values={{ name: '小伙子' }} />;
}

Readme

Keywords

Package Sidebar

Install

npm i wodax-umi-plugin-locale

Weekly Downloads

0

Version

1.0.1

License

MIT

Unpacked Size

17.7 kB

Total Files

6

Last publish

Collaborators

  • sunzhifeng