解决小程序路由超过10层限制

新建 navroter.js

javascript 复制代码
// 路由判断,小程序路由超过10层限制
// 避免小程序商品重复切换导致页面到结算单页时无法跳转到收货地址页,所以这里层级限制最大数为8
const MAX_VALUE = 8
export function navigateTo(url) {
    let pages = getCurrentPages()
    let dlt = ''
    // 查找目标页在页面栈的位置
    for (var i = 0; i < MAX_VALUE; i++) {
        if (pages[i]) {
            if (pages[i].$page && pages[i].$page.fullPath && (pages[i].$page.fullPath == url)) {
                dlt = i + 1; //目标页在栈中的位置
                break;
            }

        }
    }
    // 如果有重复则返回到页面栈页面
    if (dlt) {
        uni.navigateBack({
            delta: pages.length - dlt
        })
    } else {
        if (pages.length < MAX_VALUE) {
            uni.navigateTo({ url: url })
        } else {
            uni.redirectTo({ url: url })
        }
    }
}

main.js 全局引入

javascript 复制代码
import { navigateTo } from '@/utils/navroter.js';
Vue.prototype.navigateTo = navigateTo;

使用

javascript 复制代码
this.navigateTo(`/goods-module/goods?goods_id=${goods.goods_id}`)
相关推荐
Muxxi7 分钟前
shopify模板开发
前端
Yueyanc7 分钟前
LobeHub桌面应用的IPC通信方案解析
前端·javascript
我是若尘22 分钟前
利用资源提示关键词优化网页加载速度
前端
moyu8425 分钟前
跨域问题解析(下):Nginx代理、domain修改与postMessage解决方案
前端
moyu8439 分钟前
跨域问题解析(上):JSONP、CORS与Node代理解决方案
前端
moyu8443 分钟前
深入理解TCP的三次握手与四次挥手
前端
不一样的少年_1 小时前
头像组件崩溃、乱序、加载失败?一套队列机制+多级兜底全搞定
前端·vue.js
Code_XYZ1 小时前
uni-app x开发跨端应用,与web-view的双向通信解决方案
前端
wordbaby1 小时前
构建时规划,运行时执行:解构 React Router 的 prerender 与 loader
前端·react.js
用户5806139393001 小时前
【前端工程化】Eslint+Prettier vue项目实现文件保存时自动代码格式化
前端