- wx.switchTab()
跳轉到 tabBar 頁面,並關閉其他所有非 tabBar 頁面
{
"tabBar": {
"list": [{
"pagePath": "index",
"text": "首頁"
},{
"pagePath": "other",
"text": "其他"
}]
}
}
wx.switchTab({
url: '/index'
})
- wx.reLaunch()
關閉所有頁面,開啟到應用內的某個頁面(包括 tabBar頁面)
wx.reLaunch({
url: 'test?id=1'
})
Page({
onLoad (option) {
console.log(option.query)
}
})
- wx.redirectTo()
關閉當前頁面,跳轉到應用內的某個頁面。但是不允許跳轉到 tabbar 頁面。
Page({
onLoad (option) {
console.log(option.query)
}
})
- wx.navigateTo()
保留當前頁面,跳轉到應用內的某個頁面。但是不能跳到 tabbar 頁面。使用 wx.navigateBack 可以返回到原頁面。小程式中頁面棧最多十層
wx.navigateTo({
url: 'test?id=1',
events: {
acceptDataFromOpenedPage: function(data) {
console.log(data)
},
someEvent: function(data) {
console.log(data)
}
...
},
success: function(res) {
res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' })
}
})
Page({
onLoad: function(option){
console.log(option.query)
const eventChannel = this.getOpenerEventChannel()
eventChannel.emit('acceptDataFromOpenedPage', {data: 'test'});
eventChannel.emit('someEvent', {data: 'test'});
eventChannel.on('acceptDataFromOpenerPage', function(data) {
console.log(data)
})
}
})
- wx.navigateBack()
關閉當前頁面,返回上一頁面或多級頁面。可通過 getCurrentPages 獲取當前的頁面棧,決定需要返回幾層。(頁面棧最多十層)
wx.navigateTo({
url: 'B?id=1'
})
wx.navigateTo({
url: 'C?id=1'
})
wx.navigateBack({
delta: 2
})