关于uni-app 在app中隐藏原生tabbar uni.hideTabBar()无效问题

我们在做uniapp小程序的时候,如果不使用原生tabbar 导航,而自定义导航,会出现切换各页面闪烁问题:
原生导航切换使用的是:

    uni.switchTab({
		url: item.pagePath,	
	})

而自定义导航切换一般使用

	uni.reLaunch({
		url: item.pagePath,	
	});

uni.reLaunch 会关闭所有页面而从新加载导航页,这样就会因为dom切换,还没编译生成dom树,使页面产生闪烁问题,从而影响界面友好。

所以我们在使用自定义导航的时候, 在

第一次加载的 tabbar页

添加 uni.hideTabBar()

onLoad() {
 		  uni.hideTabBar()//隐藏官方的tabBar
 },

这样就可以隐藏app中的原生导航

1、 网上很多方法是在app.vue里引人,

但如果页面初始化打开比如说是登录页,uni.hidetabbar()在app.vue里引人,可能会无效 ,因为登录页并没有的 tabbar 组件。

3、uni.hidetabbar()方法只能在页面的生命周期函数中调用,例如 onLoad、onshow 等。如果在其他函数中调用,可能会无效

4、如果您使用了自定义的 tabbar,需要在自定义的 tabbar 组件中调用 uni.hideTabear()方法隐藏。如果您又在其他地方引入uni.hidetabbar(),也可能会无效。

uni-app就是这么神奇,web调试和app调试永远会出来各种不统一,加油优化吧

最后
uni.switchTab 和 uni.reLaunch 初始化加载的时候依然会闪烁一次,
如果有好的办法欢迎留言,请教学习~

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值