uniapp开发小程序返回上一页

小程序导航栏使用 uniapp组件   导航里的属性参数去官网查看uni-nav-bar组件

@clickLeft左侧按钮点击时触发
 <uni-nav-bar class="nav-bar-top" :fixed="true" leftIcon="arrowleft" leftText="课程报名" @clickLeft="back()"
      color="#ffffff" :border="false" :status-bar="true" />

 触发back()方法来处理返回页

getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。数组长度减一为当前页,数组长度减二为上一页

page.route  获取当前页面的路由

	back() {
			let pages = getCurrentPages();   // 获取当前页面栈的实例
			let currPage = pages[pages.length - 1];   //当前页面
			let prevPage = pages[pages.length - 2];  //上一个页面

            //判断上一页是否为首页,如果是就直接返回首页
			if(prevPage && prevPage.route && prevPage.route.indexOf("/jump") != -1){
				uni.switchTab({
					url:'/tabBar/home/index'  //路径为测试数据,填写小程序真实路径就行
				});
				return;
			}

            //uni.navigateBack() 关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages() 获取当前的页面栈,决定需要返回几层
			uni.navigateBack({
				success:() => {
                    delta: 1 //返回的页面数,如果 delta 大于现有页面数,则返回到首页。默认为1
					//console.log('success')
				},

                //失败回调直接返回首页
				fail:() => {
					//console.log('fail')
					uni.switchTab({
						url:'/tabBar/home/index'  //路径为测试数据,填写小程序真实路径就行
					})
				}
			})
		},

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值