微信小程序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 相关文章推荐
jQuery实现的原图对比窗帘效果
Jun 15 Javascript
Jquery通过JSON字符串创建JSON对象
Aug 24 Javascript
JavaScript获取文本框内选中文本的方法
Feb 20 Javascript
jQuery实现360°全景拖动展示
Mar 18 Javascript
vue-router跳转页面的方法
Feb 09 Javascript
JS实现双击内容变为可编辑状态
Mar 03 Javascript
Bootstrap导航中表单简单实现代码
Mar 06 Javascript
浅谈es6中export和export default的作用及区别
Feb 07 Javascript
Vue中控制v-for循环次数的实现方法
Sep 26 Javascript
jQuery实现ajax的嵌套请求案例分析
Feb 16 jQuery
koa大型web项目中使用路由装饰器的方法示例
Apr 02 Javascript
8个有意思的JavaScript面试题
Jul 30 Javascript
详解微信小程序之提高应用速度小技巧
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
解析thinkphp中的M()与D()方法的区别
2013/06/22 PHP
php实现的读取CSV文件函数示例
2017/02/07 PHP
kmock javascript 单元测试代码
2011/02/06 Javascript
Knockoutjs的环境搭建教程
2012/11/26 Javascript
jquery实现textarea输入字符控制(仿微博输入控制字符)
2013/04/26 Javascript
jQuery的:parent选择器定义和用法
2014/07/01 Javascript
jQuery实现简单的列表式导航菜单效果代码
2015/08/31 Javascript
JS组件中bootstrap multiselect两大组件较量
2016/01/26 Javascript
JS检测移动端横竖屏的代码
2016/05/30 Javascript
创建基于Bootstrap的下拉菜单的DropDownList的JQuery插件
2016/06/02 Javascript
浅谈几种常用的JS类定义方法
2016/06/08 Javascript
vue基于mint-ui的城市选择3级联动的示例
2017/10/25 Javascript
使用Vue如何写一个双向数据绑定(面试常见)
2018/04/20 Javascript
JavaScript实现JSON合并操作示例【递归深度合并】
2018/09/07 Javascript
javascript实现超好看的3D烟花特效
2020/01/01 Javascript
[01:02]DOTA2上海特锦赛SHOWOPEN
2016/03/25 DOTA
Python解析xml中dom元素的方法
2015/03/12 Python
Python按行读取文件的实现方法【小文件和大文件读取】
2016/09/19 Python
Python爬虫设置代理IP的方法(爬虫技巧)
2018/03/04 Python
使用PyInstaller将python转成可执行文件exe笔记
2018/05/26 Python
python中p-value的实现方式
2019/12/16 Python
使用Python Tkinter实现剪刀石头布小游戏功能
2020/10/23 Python
Python命令行参数定义及需要注意的地方
2020/11/30 Python
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
2014/09/02 HTML / CSS
AVON雅芳官网:世界上最大的美容化妆品公司之一
2016/11/02 全球购物
J2EE是技术还是平台还是框架
2016/08/14 面试题
入党自我鉴定范文
2013/10/04 职场文书
行政工作个人的自我评价
2014/02/13 职场文书
党课知识竞赛主持词
2014/04/01 职场文书
2014年入党积极分子党校培训心得体会
2014/07/08 职场文书
2014年教师节演讲稿
2014/09/03 职场文书
太行山上观后感
2015/06/05 职场文书
2015年城乡环境综合治理工作总结
2015/07/24 职场文书
HTML中table表格拆分合并(colspan、rowspan)
2021/04/07 HTML / CSS
Python Django模型详解
2021/10/05 Python
Java数组详细介绍及相关工具类
2022/04/14 Java/Android