注册登录

微信小程序页面间跳转如何监听事件?

2020-09-28
导读:在微信小程序的开发过程中,我们可定会遇到页面间相互跳转的需求,那么如何监听页面跳转之间的事件呢?我们在之前的一篇文章:艺龙微信小程序框架组件研究(附源码)为例,来...
在微信小程序的开发过程中,我们可定会遇到页面间相互跳转的需求,那么如何监听页面跳转之间的事件呢?我们在之前的一篇文章:艺龙微信小程序框架组件研究(附源码)为例,来看一看小程序在页面之间相互跳转时的事件 ...

微信小程序的开发过程中,我们可定会遇到页面间相互跳转的需求,那么如何监听页面跳转之间的事件呢?我们在之前的一篇文章:艺龙微信小程序框架组件研究为例,来看一看小程序在页面之间相互跳转时的事件机制。

我们知道微信小程序(http://www.hishop.com.cn/xiaocx/)提供打开新页面、页面重定向、页面返回、tabBar切换四种改变视图的机制,托管了页面的生命周期,并为应用提供了相应的生命周期事件,方便应用各阶段的业务处理,但页面之间相互跳转并没有相应的事件机制,例如——

1、A页面打开二级页B,B页面做了一些操作,要通知A页面做相应的处理。 
2、从B页面携带一些数据,返回到A页面

以上两种场景很常见,归结为页面间如何方便的进行交互,当然我们可以通过页面跳转传参或全局数据对象来达到目的,但是使用上有些束缚(转换参数或维护全局对象)!

微信小程序页面间跳转如何监听事件?

所以在elong小程序项目中采用事件机制解决这一问题。我们重写了navigateToAPI,A页面调用该接口进行页面跳转后,方法返回给A页面一个事件对象 event,该对象可以注册自定义事件,目标页面(B页面)可以按照业务需求触发事件响应,同时将相关数据作为参数传递到监听处callback。 
A页面 

微信小程序页面间跳转如何监听事件? 
B页面 

微信小程序页面间跳转如何监听事件?

API 

微信小程序页面间跳转如何监听事件?
微信小程序页面间跳转如何监听事件?

Event 

部分代码如下:
    Page({

        data: {

            userInfo: {}

        },

        navigateToHttp: function () {

            var event = api.Navigate.go({

                url: '../http/index',

                params: {

                    name: 'billy'

                }

            });

            event.on("listok", function (params) {

                console.log(params)

            });

        },

        navigateToExternalComponent: function () {

            var event = api.Navigate.go({

                url: '../externalComponent/index'

            });

        },

        navigateToInternalComponent: function () {

            var event = api.Navigate.go({

                url: '../internalComponent/index'

            });

        },

        navigateToPartComponent: function (params) {

            var event = api.Navigate.go({

                url: '../partComponent/index'

            });

        },

打开二级页面效果图—— 

微信小程序页面间跳转如何监听事件?

重磅推荐:小程序开店目录

第一部分:小商店是什么

第二部分:如何开通一个小商店

第三部分:如何登录小商店

第四部分:开店任务常见问题

第五部分:小商店可以卖什么

第六部分:HiShop小程序特色功能

第七部分:小程序直播

第八部分:小程序收货/物流

第九部分:小程序怎么结算

第十部分:小程序客服

第十一部分:电商创业

第十二部分:小程序游戏开发

电话咨询 微信咨询 预约演示 0元开店