Taro使用mobx做国际化小程序

时间:2023-03-09 01:25:30
Taro使用mobx做国际化小程序

效果

Taro使用mobx做国际化小程序

目前项目使用的是Taro做小程序开发框架,Taro可以集成mbox,当然一些正常的框架也可以集成mbox,只不过需要自己集成,或者用redux也可以用相同的思想实现。

思路

利用mbox action会重新render页面的能力来实现通过切换action来改变对应的语言,同样的国际化会写成一个字典数据结构的数据,通过设定统一的出口去统一读取字典中的值,并且可以实现参数代入。

核心代码

import { observable } from 'mobx'
// Language是一个函数根据参数key来返回中英文
import Language from 'src/locales/index' // 正则匹配有参数的形式
const RegEx = /#{(\w+)}/g const counterStore = observable({
// 当前使用的国际化map
T: {},
// 用来切换语言的函数
setLocales(lang = 'zh') {
this.T = Language(lang)
},
// 对外暴露get函数,通过对应的key来获取
get(key, params) {
let value = this.T[key]
if (!value) {
return ''
} if (!params) {
return value
} value = value.replace(RegEx, (a, match) => {
const v = params[match]
if (v) {
return v
} return ''
})
return value
}
})
export default counterStore

国际化初始化

根据当前手机系统设置的语言来设置当前使用的国际化文字language

@inject((stores, props) => {
return {
localesStore: stores.localesStore || {}
}
})
@observer
class App extends Component { config = {
pages: [
'pages/index'
],
window: {
}
} componentWillMount() {
try {
const system = Taro.getSystemInfoSync()
this.props.localesStore.setLocales(system.language)
} catch (e) {
console.log(e)
}
} // 在 App 类中的 render() 函数没有实际作用
// 请勿修改此函数
render () {
return (
<Provider store={store}>
<Index />
</Provider>
)
}
}

方法的使用

首先在对应的国际化文件中初始化想要设置的值

export default {
'login.phone': '手机号码',
'login.phone.placeholder': '请输入手机号码',
'login.code': '验证码',
'login.code.sendmsg': '发送验证码',
'login.btn': '登录',
'login.msg': '今日购物#{discount}的折扣'
}

在对应想要国际化的文件引入localesStore

@inject((stores, props) => {
return {
T: stores.localesStore
}
})

那么在使用的时候只需要T.get("输入想要的key","对应的params object")

<AtButton type='primary' onClick={this.login}>{ T.get('login.btn') }</AtButton>
<View>{ T.get('login.msg', { discount: '7' }) }</View>

看一下例子

这时候我们希望在三秒以后吧国际化文字从中文变成英文,下面是对应的代码:

componentWillMount() {
try {
const system = Taro.getSystemInfoSync()
this.props.localesStore.setLocales(system.language)
// 三秒以后从中文变成英文
setTimeout(() => {
this.props.localesStore.setLocales('en')
}, 3000)
} catch (e) {
console.log(e)
}
}

在对应的国际化英文文件中加入

export default {
'login.phone': '手机号码en',
'login.phone.placeholder': '请输入手机号码',
'login.code': '验证码',
'login.code.sendmsg': '发送验证码',
'login.btn': 'login',
'login.msg': "#{discount} off today's purchase discount"
}

如图,总共刷新了3次,每次3秒以后都会变成English

Taro使用mobx做国际化小程序