小程序路由跳转---事件通信通道EventChannel
warning:
这篇文章距离上次修改已过446天,其中的内容可能已经有所变动。
在小程序中,页面间的路由跳转通常是通过wx.navigateTo、wx.redirectTo等API进行。但是,有时候我们需要页面间的事件通信,例如从一个页面向另一个页面发送信息或者监听另一个页面的状态变化。在这种情况下,我们可以使用EventChannel来建立页面间的事件通信。
以下是一个使用EventChannel进行事件通信的简单例子:
页面A(发送事件):
// 获取EventChannel实例
const eventChannel = this.getOpenerEventChannel();
// 监听页面B发送过来的事件
eventChannel.on('someEvent', (data) => {
console.log(data);
});
// 发送数据到页面B
eventChannel.emit('someEvent', { data: 'Hello from Page A!' });页面B(接收事件):
// 获取EventChannel实例
const eventChannel = this.getOpenerEventChannel();
// 监听页面A发送过来的事件
eventChannel.on('someEvent', (data) => {
console.log(data);
});
// 发送数据到页面A
eventChannel.emit('someEvent', { data: 'Hello from Page B!' });在这个例子中,页面A和页面B通过getOpenerEventChannel(针对打开当前页面的页面)或getEventChannel(针对当前页面跳转到的页面)获取到EventChannel实例。然后,它们可以通过emit方法发送事件和数据,通过on方法监听事件和处理数据。
注意:getOpenerEventChannel和getEventChannel是针对不同的跳转场景设计的,使用时需要根据实际情况选择合适的方法。
评论已关闭