微信小程序页面嵌套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

相关推荐
Jackson__19 分钟前
分享一个横向滚动案例,带悬停暂停,通用性很强
前端
MariaH1 小时前
git rebase的使用
前端
_柳青杨1 小时前
深入理解 JavaScript 事件循环
前端·javascript
阡陌Jony1 小时前
关于前端性能优化的一些问题:
前端
用户600071819102 小时前
【翻译】简化 TSRX
前端
IT乐手3 小时前
佛德角逼平西班牙,国足还有啥借口?
前端
JustHappy3 小时前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
星栈4 小时前
Dioxus 的响应式系统:`Signal`、`Memo`、`Effect` 和异步状态到底该怎么分工
前端·前端框架
yingyima4 小时前
Java 正则表达式:比你想象的更强大
前端
yuanyxh6 小时前
macOS 应用 - 纯对话生成
前端·macos·ai编程