问题:
用户的交互是从首页-b页面-c页面-d页面(为h5页面) 在这个页面有一个操作 产品希望用户操作完成以后可以进行下一步,也可以点击导航栏返回,但是返回的时候产品希望直接返回到首页,所以这就回到了我们的问题 就是关于小程序webview的h5返回小程序的问题
我首先想到的是使用监听返回事件 然后使用wx的jssdk去直接返回到首页
function pushHistory(){
var state = {
title: "title",
url: "#"
}
window.history.pushState(state, "title", "#");
}
pushHistory()
2.监听 popstate 事件
window.addEventListener("popstate", function(){
//doSomething
}, false)
但是这个只有ios有效果 安卓是不行的
后来自己又想到一个取巧的办法解决:是通过jssdk的通信去解决
// wx.miniProgram.postMessage 会在webview后退或销毁的时候向小程序发送消息
wx.miniProgram.postMessage({ data: { delta: this.delta || null, userToken: this.usertoken } })
然后在webview里面使用方法收到消息 作出返回操作
bindGetMsg(e){
const {delta} = e.detail.data[0]
getApp().globalData.userToken = userToken
if(delta){
wx.navigateBack({
delta:Number(delta)
})
}
},
这样就可以适配两个型号的手机了
记录一下 如有错误 请指正