微信小程序 -- 页面间通信

前言

今天我们来说下微信小程序的页面间通信:

  1. 通过url传参实现页面间单向通信
  2. 通过getCurrentPages()页面栈实现页面间单向通信
  3. 通过EventChannel实现页面间双向通信
1、url传参

我们知道页面之间的跳转可以通过路由组件来实现,其中组件的属性url就是要跳转到页面的路径。

我们可以通过在路径中添加需要传递的数据来实现页面间数据通信

js 复制代码
//数据传递
wx.navigateTo({
	url: '../../followUp/index?aa=1256&bb=jkkk'
})
//数据接收
onLoad: function (options) {
	const {info} = options;
},
2、getCurrentPages()

获取当前页面栈。数组中第一个元素为首页,最后一个元素为当前页面。

通过获取到相应的页面栈对象,然后根据业务需求,执行具体操作。

js 复制代码
//数据传递
let curPages = getCurrentPages();//获取当前页面栈列表
var prevPage = curPages[curPages.length - 2];//上一页面栈对象
prevPage.setData({
	aa:'111111',
	bb:'2222222',
});
prevPage.updateInfo();
2、EventChannel

如果一个页面(B)由另一个页面(A)通过 wx.navigateTo 打开,这两个页面间将建立一条数据通道:

被打开的页面可以通过 this.getOpenerEventChannel() 方法来获得一个 EventChannel 对象;

wx.navigateTo 的 success 回调中也包含一个 EventChannel 对象。

这两个 EventChannel 对象间可以使用 emit 和 on 方法相互发送、监听事件。

js 复制代码
//--------------------------页面A--------------------------
wx.navigateTo({
  url: '../../followUp/index',
  events: {
  	//接收页面B传递的数据
    two: function (data) {
      console.log(data)
    },
  },
  success:function(res){
  	//向页面B传递数据
    res.eventChannel.emit('one', { data: 'data one' })
  },
})
// --------------------------页面B--------------------------
//接收数据
const eventChannel = this.getOpenerEventChannel()
eventChannel.on('one', function (data) {
  console.log(data)
})
//发送数据
const eventChannel = this.getOpenerEventChannel()
eventChannel.emit('two', { data: 'data two'});
相关推荐
漏刻有时3 小时前
微信小程序学习实录14:微信小程序手写签名功能完整开发方案
学习·微信小程序·notepad++
说私域4 小时前
全民电商时代下的链动2+1模式与S2B2C商城小程序:社交裂变与供应链协同的营销革命
开发语言·人工智能·小程序·php·流量运营
2501_915106325 小时前
iOS 抓包工具实战实践指南,围绕代理抓包、数据流抓包和拦截器等常见工具
android·ios·小程序·https·uni-app·iphone·webview
莫桐5 小时前
微信小程序tab模块滚动至顶部导航栏置顶效果实现
微信小程序·小程序
sheji34165 小时前
【开题答辩全过程】以 基于微信小程序健康跑平台的设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
棒棒的唐5 小时前
适合小程序使用的将对象数组转换为参数字符串方法
前端·javascript·小程序
努力学前端Hang6 小时前
微信小程序安装tdsign组件库
微信小程序·小程序
2501_915106326 小时前
如何在 iOS 设备上理解和分析 CPU 使用率(windows环境)
android·ios·小程序·https·uni-app·iphone·webview
weixin_177297220696 小时前
[特殊字符]旧物重生,绿色未来——旧物回收二手交易小程序,开启环保新生活[特殊字符]
小程序·生活
说私域6 小时前
链动2+1模式S2B2C商城小程序在电商直播中的应用与影响研究
大数据·人工智能·小程序·流量运营