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做国际化小程序的更多相关文章
- 想做微信小程序第三方代理,各位觉得一键生成平台能赚到钱吗?
这几年生意不景气,这是很多人的共识.从2009年开始,各种专家就判断"明年经济是最差的一年."然后,这个明年,一直"明"到了2018年,到最后,我们发现,经济就 ...
- 微信小程序开发入门教程(四)---自己动手做个小程序
前面已将基础知识准备的差不多了,下面实际做一个小程序. 一.目标 用于上传照片和文字. 2个主要页面:我me,设置set 二.开始制作 1.打开微信开发者工具(我用的1.02.1907160 Wind ...
- 使用AirtestProject+pytest做支付宝小程序UI自动化测试
一,前言 1,背景 因公司业务需要做支付宝小程序的UI自动化测试,于是在网上查找小程序的自动化资料,发现微信小程序是有自己的测试框架的,但几乎找不到支付宝小程序UI自动化测试相关的资料.白piao失败 ...
- Taro 开发踩坑指南 (小程序,H5, RN)
Taro 开发踩坑指南 (小程序,H5, RN) css taro 如何展示多行文本省略号 https://www.cnblogs.com/xgqfrms/p/12569057.html UI 设计稿 ...
- 你的产品适不适合做微信小程序?你需要这篇产品逻辑分析
自2017年1月9日张小龙宣布万众瞩目的“微信小程序”正式上线了.以名字看,感觉像是突出了“将你的程序接入微信”的意思. 我们此前分析过微信的功能迭代节奏:一般微信重要的功能规划周期,大约会在在9 ...
- 从零开始学做微信小程序,看这些就够了!
随着正式开放公测,微信小程序再次万众瞩目,越来越多的企业和个人涌入到小程序开发的大军中.小程序究竟是什么?适合做小程序的产品有哪些?做小程序需要提前准备什么?如何零基础学做小程序?此文,将列出OSC上 ...
- pyqt5 做的小程序,可以用来UI做个小demo
#!/usr/bin/python3# -*- coding: utf-8 -*- """ZetCode PyQt5 tutorial This program crea ...
- 用Taro做个微信小程序Todo, 小白工作记录
微信小程序框架: Taro 做微信小程序的框架, 几个比较主流的: 官方的WePY: https://tencent.github.io/wepy/document.html#/ 美团的mpvue: ...
- 小程序多端框架全面测评:chameleon、Taro、uni-app、mpvue、WePY
摘要: 微信小程序开发技巧. 作者:coldsnap 原文:小程序多端框架全面测评 Fundebug经授权转载,版权归原作者所有. 最近前端届多端框架频出,相信很多有代码多端运行需求的开发者都会产生一 ...
随机推荐
- unix文件系统中的硬链接和软连接
硬链接: 一般情况下,文件名和inode号码是"一一对应"关系,每个inode号码对应一个文件名.但是,Unix/Linux系统允许,多个文件名指向同一个inode号码. 这意味着 ...
- vue 中 echart 在子组件中只显示一次的问题
问题描述 一次项目开发过程中,需要做一些图表,用的是百度开源的 echarts. vue推荐组件化开发,所以就把每个图表封装成子组件,然后在需要用到该图表的父组件中直接使用. 实际开发中,数据肯定都是 ...
- Vue(小案例_vue+axios仿手机app)_go实现退回上一个路由
一.前言 this.$router.go(-1)返回上级路由 二.主要内容 1.小功能演示: 2.组件之间的嵌套关系为: 3.具体实现 (1)由于这种返回按钮在每个页面中的结构都是一样的,只是里面的数 ...
- 老男孩Python全栈学习 S9 日常作业 003
1.有变量name = "aleX leNb" 完成如下操作: # 移除 name 变量对应的值两边的空格,并输出处理结果 # 移除name变量左边的"al"并 ...
- Docker: 基础介绍 [一]
一.Docker介绍 Docker是Docker.lnc公司开源的一个基于LXC技术之上构建的Container容器引擎,源代码托管在Github上,基于Go语言并遵从Apache2.0协议开源 Do ...
- beanPostProcessor与beanFactoryPostProcessor
BeanFactoryPostProcessor的典型应用:PropertyPlaceholderConfigurer BeanFactoryPostProcessor会在所有的bean配置载入之后执 ...
- 携程apollo系列-客户端集成
本文讲解如何在 Java 程序中集成 Apollo 配置, 主要涉及到一些基础用法. 对于一些高级用法, 比如如何加密/解密配置项 (可用于数据库密码配置), 如何动态切换数据源地址,如何动态切换日志 ...
- [物理学与PDEs]第4章第3节 一维反应流体力学方程组 3.1 一维反应流体力学方程组
1. 一维粘性热传导反应流体力学方程组 $$\beex \bea \cfrac{\p\rho}{\p t}&+\cfrac{\p}{\p x}(\rho u)=0,\\ \cfrac{\p}{ ...
- /etc/profile文件被改坏导致命令不可用
这几天在装一个软件,设置环境变量的时候,不小心把/etc/profile文件改坏了(就是没配置对),在source /etc/profile后导致所有命令都不可用了.出现如下报错: -bash: xx ...
- 使用SIGALARM为connect设置超时
static void connect_alarm(int); int connect_timeo(int sockfd, const SA *saptr, socklen_t salen, int ...