微信小程序wx.navigateTo方法里的events参数使用详情及场景


Posted in Javascript onJanuary 07, 2020

个人理解wx.navigateTo方法里的events参数使用详情及场景

微信小程序在2.7.3版本wx.navigateTo这个方法中新增了events这个属性
微信官方文档里面写的很模糊,在微信公众平台的社区里也有一些人在问,我第一次看到也是先百度了一下使用场景,搜到的也只是copy官方文档的抄袭党,并没什么卵用,相信大家都是看的一头雾水,所以用业余时间研究了一下,以下仅代表个人的理解,如果有更好的想法或者使用不当的地方希望大家提出防止我的个人想法误导大家

个人理解这个新增的属性使用的场景就是能在一个页面执行另一个页面的方法,以大家最熟悉的购物为例,假设现在大家在购物的订单列表页,然后想从这个页跳转到评论订单的页面,在评论完成后刷新订单页面的订单,原来的处理方式就是评论完回到订单页在onShow方法中执行刷新订单的操作,用户体验会差一点,有了events这个属性就能解决这个问题

//订单页js,order.js
//跳转去评论页的方法
fnToComment(){
  wx.navigateTo({
   url: `../comment/comment`,
   events:{
    //执行刷新订单的操作data是从评论页传递的参数
    fnFefresh:function(data){
     console.log(data)//此处接收的是comment.js传递的{data:'2222'}
    }
   },
   success: function (res) {
    //跳转comment页要执行的方法
    res.eventChannel.emit('fresh', { data: '1111' })
   }
  })
 },
//评论页js,comment.js
var eventChannel
Page({
 /**
  * 页面的初始数据
  */
 data: {

 },
 /**
  * 生命周期函数--监听页面加载
  */
 onLoad: function (options) {
  eventChannel = this.getOpenerEventChannel()
  // 监听fresh事件,获取上一页面通过eventChannel传送到当前页面的数据
  eventChannel.on('fresh', function (data) {
   console.log(data)//此处接收的是order.js传递的{data:'1111'}
  })
 },
 //提交评论的方法同时刷新order.js的刷新订单方法
 fnComment(){
  //刷新order.js的events属性中的fnFefresh方法
  eventChannel.emit('fnFefresh', { data: '2222' });
 }
})

####### 官方给的文档传递的数据都是这个{data:‘test'},可能让大家蒙了,其实这个和vue的组件之间传递数据有点相似,emit就是相当于用于发送事件,on就是相当于接收同名的emit传递的方法,也就是说当前所在的页面(也就是执行wx.navigateTo方法的页面 )的emit的方法在被打开也就是要去的页面里on去接收传递的数据,如果被打开的页面里有执行的方法同时又要调用当前页面的方法,就在被打开页面里也有执行emit的地方,在当前页面里events参数里的方法就是接收被打开页面emit的同名的方法就能接收到被打开页面执行某一方法同时执行emit传递到当前页面的数据,也就是相当于被打开页面已经打开之后,执行某一方法可以同时调用之前执行wx.navigateTo方法的页面里面的方法,个人理解使用场景就是能在一个页面执行了另一个页面的方法,例如执行一些刷新操作之类的,防止在onshow中调用还是会被看到刷新过程影响使用体验,个人理解,不喜勿喷

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
点击按钮自动加关注的代码(sina微博/QQ空间/人人网/腾讯微博)
Jan 02 Javascript
Node.js中的缓冲与流模块详细介绍
Feb 11 Javascript
jQuery对象初始化的传参方式
Feb 26 Javascript
jquery预加载图片的方法
May 27 Javascript
简介JavaScript中toUpperCase()方法的使用
Jun 06 Javascript
javascript中arguments,callee,caller详解
Mar 16 Javascript
Jquery EasyUI $.Parser
Jun 02 jQuery
vue中使用iview自定义验证关键词输入框问题及解决方法
Mar 26 Javascript
vue中各选项及钩子函数执行顺序详解
Aug 25 Javascript
vue 兄弟组件的信息传递的方法实例详解
Aug 30 Javascript
在Vue项目中使用Typescript的实现
Dec 19 Javascript
Vue 打包的静态文件不能直接运行的原因及解决办法
Nov 19 Vue.js
详解微信小程序之提高应用速度小技巧
Jan 07 #Javascript
小程序跨页面交互的作用与方法详解
Jan 07 #Javascript
JavaScript实现联动菜单特效
Jan 07 #Javascript
JS实现电商商品展示放大镜特效
Jan 07 #Javascript
JS实现字体背景跑马灯
Jan 06 #Javascript
JS实现音乐钢琴特效
Jan 06 #Javascript
React Native中ScrollView组件轮播图与ListView渲染列表组件用法实例分析
Jan 06 #Javascript
You might like
PHP数组游标实现对数组的各种操作详解
2016/01/26 PHP
PHP+MYSQL实现读写分离简单实战
2017/03/13 PHP
PHP长连接实现与使用方法详解
2018/02/11 PHP
TP5框架简单登录功能实现方法示例
2019/10/31 PHP
javascript中的undefined 与 null 的区别  补充篇
2010/03/17 Javascript
jQuery+ajax实现顶一下,踩一下效果
2010/07/17 Javascript
javascript强制点击广告的方法
2015/02/06 Javascript
有关json_decode乱码及NULL的问题
2015/10/13 Javascript
JS闭包、作用域链、垃圾回收、内存泄露相关知识小结
2016/05/16 Javascript
javascript url几种编码方式详解
2016/06/06 Javascript
Three.js学习之正交投影照相机
2016/08/01 Javascript
Angular4学习笔记之新建项目的方法
2017/07/18 Javascript
jQuery Layer弹出层传值到父页面的实现代码
2017/08/17 jQuery
Vue递归组件+Vuex开发树形组件Tree--递归组件的简单实现
2019/04/01 Javascript
element form 校验数组每一项实例代码
2019/10/10 Javascript
Vue的props父传子的示例代码
2020/05/20 Javascript
Windows系统下安装Python的SSH模块教程
2015/02/05 Python
python 循环遍历字典元素的简单方法
2016/09/11 Python
python利用dir函数查看类中所有成员函数示例代码
2017/09/08 Python
python实现定时提取实时日志程序
2018/06/22 Python
Python类如何定义私有变量
2020/02/03 Python
Django模板标签中url使用详解(url跳转到指定页面)
2020/03/19 Python
python filecmp.dircmp实现递归比对两个目录的方法
2020/05/22 Python
Python根据URL地址下载文件并保存至对应目录的实现
2020/11/15 Python
HTML5 对各个标签的定义与规定:body的介绍
2012/06/21 HTML / CSS
全天然狗零食:Best Bully Sticks
2016/09/22 全球购物
有机童装:Toby Tiger
2018/05/23 全球购物
课改先进个人汇报材料
2014/01/26 职场文书
个人简历中自我评价
2014/02/11 职场文书
统计系教授推荐信
2014/02/28 职场文书
计算机专业毕业生求职信
2014/04/30 职场文书
车辆年审委托书范本
2014/09/18 职场文书
公务员年度考核个人总结
2015/02/12 职场文书
老兵退伍感言
2015/08/03 职场文书
导游词之河北野三坡
2019/12/11 职场文书
Python Django ORM连表正反操作技巧
2021/06/13 Python