微信小程序navigateTo和redirectTo交替使用报错navigateTo:fail webview count limit exceed

navigateTo:fail webview count limit exceed

前言

小程序的头部默认使用 wx.navigateBack 关闭当前页面,返回上一页面或多级页面。然后在自定义小程序头部后,返回按钮可以调用其他API。当 wx.navigateTowx.redirectTo 交替反复使用时,报错 navigateTo:fail webview count limit exceed
在这里插入图片描述
您可以点击小程序代码片段 minicode-27

步骤

在小程序用 a 页面使用 wx.navigateTo 跳转到 b 页面,然后在 b 页面使用 wx.redirectTo 返回 a 页面。如此交替切换页面,最终页面栈超过 10 个,页面报错 navigateTo:fail webview count limit exceed

代码

  • 首页
// index.js
Page({
  onNavigateTo () {
    console.warn('通过 navigateTo 进入 redirectPage 页面');
    wx.navigateTo({
      url: '/redirectPage/redirectPage'
    })
  },
  onShow () {
    const pages = [...getCurrentPages()]
    console.log('index页面中,页面栈总数', pages.length, pages)
  },
})
<!-- index.wxml -->
<button type="primary" bindtap="onNavigateTo">通过 navigateTo 进入 redirectPage 页面</button>
  • redirectPage页面
// redirectPage.js
Component({
  pageLifetimes: {
    show: function () {
      const pages = [...getCurrentPages()]
      console.log('redirectPage页面中,页面栈总数', pages.length, pages)
    },
  },
  methods: {
    toIndex () {
      console.warn('通过 redirectTo 返回 首页');
      wx.redirectTo({
        url: '/index/index'
      })
    }
  },
})
<!-- redirectPage.wxml -->
<view>
  redirectPage页面
</view>
<button type="primary" bindtap="toIndex">返回首页</button>

报错原因

wx.navigateTo 保留当前页面,跳转到应用内的某个页面。
wx.redirectTo 关闭当前页面,跳转到应用内的某个页面。

  • 初始化:第一次打开首页,页面栈为 1,只包含首页。
  • 步骤1:从首页 navigateTo 到 redirectPage页面,页面栈为2。
  • 步骤2:再从 redirectPage页面,通过 redirectTo 返回首页,页面栈为2。
  • 重复步骤1 和步骤2。

  • 最后页面栈有10层,已经无法跳转页面,并且报错 navigateTo:fail webview count limit exceed

建议

  • wx.navigateTo 配合 wx.navigateBack 使用
  • 小程序从 a 页面 -> b 页面 -> c 页面 -> d -> 页面 -> e 页面 -> f 页面等,页面层级较深时,当页面 d既可以返回页面 a,又可以返回页面 c时。返回页面 c用 wx.navigateBack ,返回页面 a使用 wx.reLaunch 更佳,关闭所有页面,打开到应用内的某个页面。
  • 页面无需保留,跳转到一个新页面时,使用 redirectTo
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值