微信小程序页面嵌套web-view点击系统导航返回时进行弹窗处理

实现效果 :微信小程序页面嵌套web-view点击系统导航返回时进行弹窗处理

首先在web-view里是不可实现的(据我了解下来)

参考小程序文档:page-container

大致逻辑:

1、page-container可实现页面离开前拦截

2、由于web-view层级最高,导致page-container里弹窗展示不出来,可使用cover-view来做弹窗,page-container只做拦截作用

index.wxml:

javascript 复制代码
<!-- page.wxml -->
<web-view src="https://www.baidu.com"/>
<page-container
  show="{{showBackConfirm}}"
  bindbeforeleave="handleBackAttempt"
  bind:afterleave="resetInterceptor" 
>
</page-container>
<cover-view wx:if="{{isIntercepting}}" class="evaluate">
  <cover-view class="content">
    <cover-view>您觉得本次服务怎么样?</cover-view>
    <cover-view class="star-list">
      <cover-image class="star" src="/assets/collect-block.png"></cover-image>
      <cover-image class="star" src="/assets/collect-block.png"></cover-image>
      <cover-image class="star" src="/assets/collect-block.png"></cover-image>
      <cover-image class="star" src="/assets/collect-block.png"></cover-image>
      <cover-image class="star" src="/assets/collect-block.png"></cover-image>
    </cover-view>
    <cover-view class="btns">
      <button bind:tap="cancelBack">取消</button>
      <button bind:tap="confirmBack">已评价</button>
    </cover-view>
  </cover-view>
</cover-view>

index.js:

javascript 复制代码
Page({
  data: {
    showBackConfirm: true,
    isIntercepting: false // 状态锁,防止重复触发
  },

  // ✅ 核心拦截函数(修正导航栏返回不生效问题)
  handleBackAttempt() {
    if (!this.data.isIntercepting) {
      this.setData({
        showBackConfirm: true,
        isIntercepting: true // 加锁
      }, () => {
        // 确保弹窗渲染完成
        wx.nextTick(() => {
          return false; // 必须返回 false 才能拦截
        });
      });
    }
    return false; // 双重保险
  },

  // ✅ 用户确认返回
  confirmBack() {
    this.setData({
      showBackConfirm: false
    }, () => {
      setTimeout(() => wx.navigateBack(), 50); // 确保弹窗关闭后再返回
    });
  },
  // ✅ 用户取消返回
  cancelBack() {
    this.setData({
      showBackConfirm: true,
      isIntercepting: false // 解锁
    });
  },
  // ✅ Android 物理返回键专项处理
  onBackPress() {
    if (!this.data.isIntercepting) {
      this.setData({
        showBackConfirm: true
      });
      return true; // 必须返回 true 才能拦截
    }
    return false;
  },

  // ✅ 阻止 iOS 右滑穿透(关键!)
  preventSwipe() {
    return; // 空函数阻止默认滑动
  },

  // ✅ 重置拦截状态
  resetInterceptor() {
    this.setData({
      isIntercepting: false
    });
  }
})

代码片段:https://developers.weixin.qq.com/s/As1z2uma8Q0i

相关推荐
云起SAAS12 分钟前
漂流瓶小游戏流量主微信小程序开源
微信小程序·小程序·漂流瓶小游戏流量主微信
aiweker2 小时前
python web开发-Flask 蓝图(Blueprints)完全指南
前端·python·flask
Justin3go8 小时前
两年后又捣鼓了一个健康类小程序
前端·微信小程序
5720 天窗9 小时前
解决uni-app发布微信小程序主包大小限制为<2M的问题
微信小程序·小程序·uni-app
巴巴_羊10 小时前
xss和csrf
前端·xss·csrf
华子w90892585910 小时前
基于 Python Web 应用框架 Django 的在线小说阅读平台设计与实现
前端·python·django
烛阴10 小时前
让你的Python并发飞起来:多线程开发实用技巧大全
前端·python
旺代10 小时前
Vue3中的v-model、computed、watch
前端
excel11 小时前
微信小程序鉴权登录详解 —— 基于 wx.login 与后端 openid 换取流程
前端
Gazer_S11 小时前
【前端隐蔽 Bug 深度剖析:SVG 组件复用中的 ID 冲突陷阱】
前端·bug