• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

uni-app 普通页面跳转到tabBar页面附加代码+uni.switchTab使用

武飞扬头像
夏小花花
帮助1

大家好!最近几周我发现,每周一都会头疼Bug让我遇到,下面来简单介绍一下,今天遇到了哪个头疼问题!

问题描述

首先先说下实现什么功能:
我想从一个普通页面跳转到tabBar中页面(这里指的页面是:小程序中底部导航那几个图标点击后所对应的页面),一开始我使用的是uni.navigateTo,但是跳转没有效果,在网上搜索了一下,要使用uni.switchTab来解决普通页面跳转到tabBar页面,试了一下没有问题。
我还有一个问题是:举例A页面跳转到B页面,执行某些渲染B页面的方法,我一开始是在B页面中的onLoad里面进行接收A页面的参数,但是发现了一个问题!
如果是用onLoad,接收参数,并且每次跳转都要刷新页面,是不可以的,要是使用onShow可以解决这个问题,我专门整理了一下onShow和onLoad的区别

onShow和onLoad的区别

onLoad: 是在页面加载时触发,用于页面的初始化操作,只执行一次。
onShow: 是在页面展示时触发,用于处理页面显示相关的逻辑,可能会多次执行,包括页面首次展示和从后台切换到前台时。
我现在的这个场景下比较适合用onShow
下面以代码的形式进行展现,普通页面跳转到tabBar页面

解决方案

A页面代码
我这边是做了一个值的判断,并且没有携带参数如果需要携带参数的直接在index后面加个?跟参数名字和参数值,示例/pages/test/index?id=value

if(value==2){
 uni.setStorageSync('param1', value-2);
  uni.switchTab({
    url: '/pages/test/index',
  });
}

B页面代码
我这个地方使用的缓存,但是感觉这块没有必要去用缓存,我后期把它去掉,进行参数传递就可以,如果你的需求和我的一样每次跳转都要刷新页面,就放到onShow的里面

onShow() {
   this.indexTab = uni.getStorageSync('param1');
   console.log('param1:', this.indexTab);
   uni.removeStorageSync('param1'); // 清除本地存储的参数,如果需要
},

结束语

本次就是普通页面跳转到tabBar页面详解以及onShow和onLoad的区别,最近一直在项目上挺忙的,后期可以分享一下关于ant design vue方面的技术,包括redis分布式缓存等。
如果你有不明白的地方我还会免费为你进行解答,希望能帮助到大家!

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgkhihc
系列文章
更多 icon
同类精品
更多 icon
继续加载