uniapp 普通页面跳转到tabBar页面详解(附加代码+uni.switchTab使用)

文章目录

  • 问题描述
    • onShow和onLoad的区别
  • 解决方案
  • 结束语

大家好!最近几周我发现,每周一都会头疼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分布式缓存等。
如果你有不明白的地方我还会免费为你进行解答,希望能帮助到大家!

你可能感兴趣的:(uniapp,javascript,Vue,uni-app,vue.js,javascript,前端,微信小程序)