让微信小程序页面之间的通信不在变得困难
一个开始
小程序开发者总会碰到各种页面之间的通信问题,实现方式也五花八门,比如...
场景还原
首先这是一个电商小程序。
有这样一个需求:
- 首页某个地方要展示购物车商品数量。
- 当我在其他页面加购了商品,首页数量刷新。
实现方式
- 方式一: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);
}
}))
最后
让微信小程序页面之间的通信不在变得困难的更多相关文章
- 微信小程序——页面之间传递值
小程序页面传值的方式: 1.正向传值:上一页面 --> 下一页面 url传值 本地储存 全局的app对象 2.反向传值:下一页面 --> 上一页面 本地储存 全局的app对象 先说一下 ...
- 微信小程序页面之间的跳转
一.使用标签跳转 index.wxml: 在index.wxml页面添加一个<navigator>元素,在元素里面使用属性url就可以 二. ...
- 在微信小程序页面间传递数据总结
在微信小程序页面间传递数据 原文链接:https://www.jianshu.com/p/dae1bac5fc75 在开发微信小程序过程之中,遇到这么一些需要在微信小程序页面之间进行数据的传递的情况, ...
- [转] 微信小程序页面间通信的5种方式
微信小程序页面间通的5种方式 PageModel(页面模型)对小程序而言是很重要的一个概念,从app.json中也可以看到,小程序就是由一个个页面组成的. 如上图,这是一个常见结构的小程序:首页是一个 ...
- 微信小程序页面通信
目录 微信小程序页面通信 方式一:通过URL 方式二:通过全局变量 方式三:通过本地存储 方式四:通过路由栈 微信小程序页面通信 方式一:通过URL // A 页面 wx.navigateTo({ u ...
- 微信小程序--页面与组件之间如何进行信息传递和函数调用
微信小程序--页面与组件之间如何进行信息传递和函数调用 这篇文章我会以我自己开发经验从如下几个角度来讲解相关的内容 页面如何向组件传数据 组件如何向页面传数据 页面如何调用组件内的函数 组件如何调 ...
- 微信小程序与Java后台通信
一.写在前面 最近接触了小程序的开发,后端选择Java,因为小程序的代码运行在腾讯的服务器上,而我们自己编写的Java代码运行在我们自己部署的服务器上,所以一开始不是很明白小程序如何与后台进行通信的, ...
- 微信小程序页面跳转方法总结
微信小程序页面跳转目前有以下方法(不全面的欢迎补充): 1. 利用小程序提供的 API 跳转: // 保留当前页面,跳转到应用内的某个页面,使用wx.navigateBack可以返回到原页面.// 注 ...
- 微信小程序页面调用自定义组件内的事件
微信小程序页面调用自定义组件内的事件 page page.json { "usingComponents": { "my-component": ". ...
随机推荐
- 2.Jmeter 快速入门教程(二)--创建简单web测试 打印 E-mail
今天我们就来实际用Jmeter创建一个测试场景,并进行性能测试. 注:由于本人使用中文版本,使用英文版本的请注意具体的菜单及参数名称. 1. 添加线程组(相当于lr里的scenario 设置) 打开j ...
- jmeter Thread Groups的顺序执行与并行执行
本期目标: 理解Thread Groups的顺序执行与并行执行 控制因子:Run Thread Groups consecutively(i.e.one at time) 预期结论: 1.勾选 Run ...
- yum update过程中失败后再次执行出现“xxxx is a duplicate with xxxx”问题
问题现象: 解决办法: 利用yum-uitls中的工具package-cleanup指令,使用方法见下图,具体可通过man package-cleanup查询 列出重复的rpm包 pac ...
- Android多线程:深入分析 Handler机制源码(二)
前言 在Android开发的多线程应用场景中,Handler机制十分常用 接下来,深入分析 Handler机制的源码,希望加深理解 目录 1. Handler 机制简介 定义一套 Android 消息 ...
- koa2 的处理请求体koa-bodyparser koa-router 的中间件的学习
1.官网 https://www.npmjs.com/package/koa-router https://www.npmjs.com/package/koa-bodyparser 2. demo / ...
- js中获取basePath
单独js文件中el不能获取,通过以下方式获取1 var location = (window.location+'').split('/'); var basePath = location[0]+' ...
- Uninstall NetBeans
There will be a file named uninstall.sh in /usr/local/netbeans-x.x if you installed netbeans with ro ...
- Scala(一)基础
OOP 面向对象编程 AOP 面向切面编程 FP 函数式编程 编程语言都要定义变量,一些代码是用来注释的,变量和变量之间有一些关系,要做一些运算,运算离不开流程控制,进行运算的数据往往来自数据结构,最 ...
- Go基础之基本数据类型
Go基础之基本数据类型 基本数据类型 整形 int8.int16.int32.int64 无符号整形:uint8.uint16.uint32.uint64 uint8就是我们熟知的byte型 类型 描 ...
- pygame游戏框架
#_author:来童星#date:2019/12/22 import pygame import sys pygame.init() size=width,height=640,480 screen ...