Taro使用mobx做国际化小程序

效果

image-20190130155918427

目前项目使用的是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

posted @ 2019-01-30 16:22  kitebear  阅读(582)  评论(0编辑  收藏  举报