关于小程序webview的h5返回小程序监听问题解决

问题:

用户的交互是从首页-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)
					})
				}
			},

这样就可以适配两个型号的手机了

记录一下 如有错误 请指正

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值