当前位置:   article > 正文

如何在 vue 跳转html 页面_有关微信小程序页面间的跳转如何监听事件详解

vue 小程序开发 打开html

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

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

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

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

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

aec8db28003fc6f30426a68189610d3f.png


B页面

1a1ff41807b294ef6a7074cebc356c9d.png

API

ae29c2bfc4e428aae031b26e7ed2e2ea.png

Event

796103e0c3a200926579ad482317dc7e.png

部分代码如下:

[AppleScript] 纯文本查看 复制代码

  1. Page({
  2. data: {
  3. userInfo: {}
  4. },
  5. navigateToHttp: function () {
  6. var event = api.Navigate.go({
  7. url: '../http/index',
  8. params: {
  9. name: 'billy'
  10. }
  11. });
  12. event.on("listok", function (params) {
  13. console.log(params)
  14. });
  15. },
  16. navigateToExternalComponent: function () {
  17. var event = api.Navigate.go({
  18. url: '../externalComponent/index'
  19. });
  20. },
  21. navigateToInternalComponent: function () {
  22. var event = api.Navigate.go({
  23. url: '../internalComponent/index'
  24. });
  25. },
  26. navigateToPartComponent: function (params) {
  27. var event = api.Navigate.go({
  28. url: '../partComponent/index'
  29. });
  30. },

打开二级页面效果图——

0d0d4402fdbbb360f570c0cd00747b14.png
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/123828
推荐阅读
相关标签
  

闽ICP备14008679号