微信小程序Redux绑定实例详解


Posted in Javascript onJune 07, 2017

微信小程序Redux绑定实例详解

安装

clone或者下载代码库到本地:

git clone https://github.com/charleyw/wechat-weapp-redux

将dist/wechat-weapp-redux.js(或者拷贝minify的也可以)文件直接拷贝到小程序的工程中,例如(下面假设我们把第三方包都安装在libs目录下):

cd wechat-weapp-redux
 cp -r dist/wechat-weapp-redux.js <小程序根目录>/libs

上面的命令将包拷贝到小程序的libs目录下

使用

1.将Redux Store绑定到App上。

const store = createStore(reducer) // redux store
 
 const WeAppRedux = require('./libs/wechat-weapp-redux/index.js');
 const {Provider} = WeAppRedux;

Provider是用来把Redux的store绑定到App上。

App(Provider(store)({
 onLaunch: function () {
  console.log("onLaunch")
 }
}))

provider的实现只是简单的将store加到App这个global对象上,方便在页面中用getApp取出来

上面这段代码等同于:

App({
 onLaunch: function() {
   console.log( "onLaunch" )
  },
  store: store
})

2.在页面的定义上使用connect,绑定redux store到页面上。

const pageConfig = {
  data: {
  },
  ...
 }

页面的定义

const mapStateToData = state => ({
  todos: state.todos,
  visibilityFilter: state.visibilityFilter
 })

定义要映射哪些state到页面

const mapDispatchToPage = dispatch => ({
  setVisibilityFilter: filter => dispatch(setVisibilityFilter(filter)),
  toggleTodo: id => dispatch(toggleTodo(id)),
  addTodo: text => dispatch(addTodo(text)),
 })

定义要映射哪些方法到页面

const nextPageConfig = connect(mapStateToData, mapDispatchToPage)(pageConfig)

使用connect将上述定义添加到pageConfig中。

Page(nextPageConfig);

注册小程序的页面

3.说明

完成上述两步之后,你就可以在this.data中访问你在mapStateToData定义的数据了。

mapDispatchToPage定义的action会被映射到this对象上。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
文字不间断滚动(上下左右)实例代码
Apr 21 Javascript
jQuery判断元素是否存在的可靠方法
May 06 Javascript
JS密码生成与强度检测完整实例(附demo源码下载)
Apr 06 Javascript
浅析javascript中的Event事件
Dec 09 Javascript
js实现下拉菜单效果
Mar 01 Javascript
AngularJs+Bootstrap实现漂亮的计算器
Aug 10 Javascript
js 客户端打印html 并且去掉页眉、页脚的实例
Nov 03 Javascript
微信小程序wx.request实现后台数据交互功能分析
Nov 25 Javascript
Vue中使用Sortable的示例代码
Apr 07 Javascript
详解Require.js与Sea.js的区别
Aug 05 Javascript
mpvue微信小程序多列选择器用法之省份城市选择的实现
Mar 07 Javascript
Nuxt v-bind绑定img src不显示的解决
Dec 05 Javascript
Ionic3 UI组件之Gallery Modal详解
Jun 07 #Javascript
vue2.0 中#$emit,$on的使用详解
Jun 07 #Javascript
vue2.0 自定义日期时间过滤器
Jun 07 #Javascript
详解Node.js 命令行程序开发教程
Jun 07 #Javascript
详解vee-validate的使用个人小结
Jun 07 #Javascript
微信小程序多张图片上传功能
Jun 07 #Javascript
Vue.js对象转换实例
Jun 07 #Javascript
You might like
php中目录,文件操作详谈
2007/03/19 PHP
详解PHP内置访问资源的超时时间 time_out file_get_contents read_file
2013/06/03 PHP
jQuery右键菜单contextMenu使用实例
2011/09/28 Javascript
Extjs显示从数据库取出时间转换JSON后的出现问题
2012/11/20 Javascript
Jquery easyui 下loaing效果示例代码
2013/08/12 Javascript
window.showModalDialog()返回值的学习心得总结
2014/01/07 Javascript
利用jQuery实现可以编辑的表格
2014/05/26 Javascript
js设置控件的隐藏与显示的两种方法
2014/08/21 Javascript
JavaScript自定义等待wait函数实例分析
2015/03/23 Javascript
jquery横向纵向鼠标滚轮全屏切换
2017/02/27 Javascript
JavaScript实现的选择排序算法实例分析
2017/04/14 Javascript
详解利用jsx写vue组件的方法示例
2017/07/17 Javascript
vue 实现全选全不选的示例代码
2018/03/29 Javascript
浅谈vue-router路由切换 组件重用挖下的坑
2019/11/01 Javascript
vue实现在线预览pdf文件和下载(pdf.js)
2019/11/26 Javascript
nodeJs的安装与npm全局环境变量的配置详解
2020/01/06 NodeJs
JS浏览器BOM常见操作实例详解
2020/04/27 Javascript
vue打开其他项目页面并传入数据详解
2020/11/25 Vue.js
Python的时间模块datetime详解
2017/04/17 Python
python判断一个集合是否为另一个集合的子集方法
2018/05/04 Python
解决python写入mysql中datetime类型遇到的问题
2018/06/21 Python
Python数据类型之String字符串实例详解
2019/05/08 Python
Python爬虫 bilibili视频弹幕提取过程详解
2019/07/31 Python
python numpy生成等差数列、等比数列的实例
2020/02/25 Python
matplotlib部件之套索Lasso的使用
2021/02/24 Python
学习委员自我鉴定
2014/01/13 职场文书
医学生自我评价
2014/01/27 职场文书
股东协议书
2014/04/14 职场文书
国际商务专业求职信
2014/07/15 职场文书
2014年军人思想汇报范文
2014/10/12 职场文书
写给同学的新学期寄语
2015/02/27 职场文书
党员志愿者服务倡议书
2015/04/29 职场文书
读书笔记怎么写
2015/07/01 职场文书
小学班主任心得体会
2016/01/07 职场文书
深入探讨opencv图像矫正算法实战
2021/05/21 Python
NASA 机智号火星直升机拍到了毅力号设备碎片
2022/04/29 数码科技