先了解下几种路由跳转
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)
})
}
})