如何让微信小程序页面之间的通信不再变困难


Posted in Javascript onJune 03, 2019

一个开始

小程序开发者总会碰到各种页面之间的通信问题,实现方式也五花八门,比如...

场景还原

首先这是一个电商小程序。

有这样一个需求:

  • 首页某个地方要展示购物车商品数量。
  • 当我在其他页面加购了商品,首页数量刷新。

实现方式

方式一:onShow直接请求接口

Page({
 onShow() {
 // ...一些逻辑
 
 // 后端请求新的购物车数量
 this.requestCartNum();
 }
})

不足: 每次onShow都要请求接口,浪费资源。

方式二:globalData存储购物车数量,onShow中做刷新

// 主页.js
Page({
 onShow() {
  // 在globalData获取到购物车数据
  let num = globalData.cartNum;
  if (num !== this.data.cartNum) {
   this.setData({
    cartNum: num,
   });
  }
 }
});

// 加购页.js
Page({
 // 加购后改变globalData的值
 cartAdd(num) {
  globalData.cartNum = globalData.cartNum + num;
 }
})

方式三:加购后获取首页实例,调用首页方法

// 首页.js
Page({
 onCartAdd(num) {
  this.setData({
   cartNum: this.data.cartNum + num,
  });
 },
});

// 加购页.js
Page({
 onCartAdd(num) {
  // 加购后获取到首页的实例,调用首页onCartAdd方法
  let pages = getCurrentPages();
  let curPage = pages[0];
  curPage.onCartAdd(num);
 }
})

不足:不确定能不能准确拿到首页的实例,如果换做其他页面就很难复用

方法四:事件订阅与发布

// 首页.js
Page({
 onLoad() {
  // 首页监听事件
  this.$bus.on('cart_add', (num) => {
   this.setData({
    cartNum: this.data.cartNum + num,
   })
  })
 }
})

// 加购页.js

Page({
 // 加购成功后触发cart_add事件
 onCartAdd(num) {
  this.$bus.emit('cart_add', num);
 }
})

此方法用事件系统,订阅发布模式去做的处理。

以上几种方法中最优解决方案是方法四,利用事件的订阅与发布,逻辑清晰兼容性好。但是都不可避免的不足是:每一个需要动态显示购物数量的页面都需要添加相同的逻辑代码。

状态管理方案

单页应用中最常用的就是组件之间的通信,由此诞生了不同的状态存储方案: react用redux, vue用vuex。他们的思路都是类似的。都有一个核心 store 存储着一切要管理的状态。

那么,其他框架可以,小程序也可以。以redux为例,实现一套简单的状态管理方案。

wxdux的实现

使用前提:有redux基础

wxdux 类似与redux,以action来描述触发的行为,reducer来描述state的变化。

1. 小程序入口中注册

注册store并添加到globalData中去

import {createStore} from './wxdux/index';
import reducer from './reducer';

const store = createStore(reducer);

App({
 globalData: {
  store,
 },
});

2. reducer实现

写法与redux类似,功能也类似。

const userReducer = (state = {}, action) => {
 // ...
}

const postReducer = (state = [], action) => {
 // ...
};

const reducers = {
 user: userReducer,
 posts: postReducer,
};

export default reducers;

3. 页面中使用wxdux

connect方法会将小程序页面实例与wxdux连接起来,必须提供$useState方法,该方法接收state,返回该页面所需要的state

import {connect} from './wxdux/index';

Page(connect({
 data: {
  sex: '男',
 },
 onLoad() {
  // ...
 },
 $useState(state) {
  return {
   name: state.name,
  },
 },
}))

4. wxml中使用name

<view>{{name}}</view>

5. 触发store更新

使用dispatch方法,该方法接收一个对象作为参数,该对象必须包含type字段表示action的类型,wxdux会根据此action更新state并且刷新所有使用name的视图

import {dispatch} from './wxdux/index';

Page(connect({
 // 某点击事件触发,更新姓名为“张三”
 onClick() {
  const updateName = {
   type: 'update_name',
   name: '张三'
  };
  dispatch(updateName);
 }
}))

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
通过JS 获取Mouse Position(鼠标坐标)的代码
Sep 21 Javascript
基于jQuery中对数组进行操作的方法
Apr 16 Javascript
用js+iframe形成页面的一种遮罩效果的具体实现
Dec 31 Javascript
引用外部脚本时script标签关闭的写法
Jan 20 Javascript
js身份证判断方法支持15位和18位
Mar 18 Javascript
javascript中通过arguments参数伪装方法重载
Oct 08 Javascript
javascript实现页面刷新时自动清空表单并选中的方法
Jul 18 Javascript
详解ES6之用let声明变量以及let loop机制
Jul 15 Javascript
微信小程序用户自定义模版用法实例分析
Nov 28 Javascript
基于vue中解决v-for使用报红并出现警告的问题
Mar 03 Javascript
基于Vue中点击组件外关闭组件的实现方法
Mar 06 Javascript
vue 1.0 结合animate.css定义动画效果
Jul 11 Javascript
使用VueRouter的addRoutes方法实现动态添加用户的权限路由
Jun 03 #Javascript
使用watch在微信小程序中实现全局状态共享
Jun 03 #Javascript
深入理解JS异步编程-Promise
Jun 03 #Javascript
模块化react-router配置方法详解
Jun 03 #Javascript
react 组件传值的三种方法
Jun 03 #Javascript
angular使用md5,CryptoJS des加密的方法
Jun 03 #Javascript
Node.js 的 GC 机制详解
Jun 03 #Javascript
You might like
php调整gif动画图片尺寸示例代码分享
2013/12/05 PHP
PHP并发查询MySQL的实例代码
2017/08/09 PHP
360搜索引擎自动收录php改写方案
2018/04/28 PHP
JavaScript基本编码模式小结
2012/05/23 Javascript
jquery设置元素的readonly和disabled的写法
2013/09/22 Javascript
一个js导致的jquery失效问题的解决方法
2013/11/27 Javascript
js操作输入框提示信息且响应鼠标事件
2014/03/25 Javascript
SpringMVC restful 注解之@RequestBody进行json与object转换
2015/12/10 Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
2016/09/19 Javascript
js实现百度地图定位于地址逆解析,显示自己当前的地理位置
2016/12/08 Javascript
基于jQuery实现瀑布流页面
2017/04/11 jQuery
BootStrap Select清除选中的状态恢复默认状态
2017/06/20 Javascript
简述jQuery Easyui一些用法
2017/08/01 jQuery
Vue Router的懒加载路径的解决方法
2018/06/21 Javascript
在create-react-app中使用css modules的示例代码
2018/07/31 Javascript
JointJS流程图的绘制方法
2018/12/03 Javascript
vue 列表页跳转详情页获取id以及详情页通过id获取数据
2019/03/27 Javascript
小程序最新获取用户昵称和头像的方法总结
2019/09/23 Javascript
JavaScript Date对象功能与用法学习记录
2020/04/28 Javascript
JS页面动态绘图工具SVG,Canvas,VML介简介
2020/10/16 Javascript
通过滑动翻页效果实现和移动端click事件问题
2021/01/26 Javascript
[00:34]TI7不朽珍藏III——地穴编织者不朽展示
2017/07/15 DOTA
Python笔记(叁)继续学习
2012/10/24 Python
Django model序列化为json的方法示例
2018/10/16 Python
Python中 Global和Nonlocal的用法详解
2020/01/20 Python
Anaconda详细安装步骤图文教程
2020/11/12 Python
利用纯html5绘制出来的一款非常漂亮的时钟
2015/01/04 HTML / CSS
CLR与IL分别是什么含义
2016/08/23 面试题
工作失职检讨书范文
2014/01/16 职场文书
家居饰品店创业计划书
2014/01/31 职场文书
优秀共产党员推荐材料
2014/12/18 职场文书
学校拾金不昧表扬信
2015/01/16 职场文书
交通事故调解协议书
2015/05/20 职场文书
总经理年会致辞
2015/07/29 职场文书
2016猴年开门红标语口号
2015/12/26 职场文书
“学党章、守党纪、讲党规”学习心得体会
2016/01/14 职场文书