微信小程序路由(组件之间跳转)传参和传数据

先了解下几种路由跳转
wx.redirectTo(Object object) 关闭当前页面,跳转到应用内的某个页面。(销毁跳转)
不能跳转到 tabbar的页面
wx.navigateTo(Object object) 保留当前页面,跳转到应用内的某个页面。
不能跳转到 tabbar的页面
wx.switchTab(Object object) 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
wx.reLaunch(Object object) 关闭所有页面,打开到应用内的某个页面 (销毁跳转)
wx.navigateBack(Object object) 关闭当前页面,返回上一页面或多级页面 (销毁跳转)
例子
###如果参数要从页面获取的,可以在元素上绑定自定义属性 data-id="{{}}" 然后从绑定处理函数行参e中获取到自定义属性值,然后在用js拼接到url进行传参

wx.navigateTo({
  url: 'test?id=1', //向新路由传参 id=1
  //组件间传数据  
  // 接收数据 
  events: {
    // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据
    aa: function(data) {
      console.log(data)
    },
    bb: function(data) {
      console.log(data)
    }
    ...
  },
  //传出数据
  success: function(res) {
    // 通过eventChannel向被打开页面传送数据
    res.eventChannel.emit('cc', { data: 'test' })
  }
})

跳转到的路由 js

//test.js
Page({
  onLoad: function(option){
    console.log(option) //这里能查到跳转传递的参数
    const eventChannel = this.getOpenerEventChannel()
    //引入这个模块用来接收 传递的数据 或者 传出的数据
    //传出数据
    eventChannel.emit('aa', {data: 'test'});
    eventChannel.emit('bb', {data: 'test'});
    // 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据
    eventChannel.on('cc', function(data) {
      console.log(data)
    })
  }
})
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值