微信小程序自定义tabbar闪烁问题

闪烁问题原因:超过两个tabbar页不要单纯的使用官方说的show时getTabBar().setData设置选中态,自定义tabbar是多个实例的,那样只会改变当前tabbar实例的选中态,其他页面的tabbar实例并没有改变选中态。

解决tabbar闪烁问题:

1.在app.js中设置 globalData

// app.js

App({
  globalData: {
    tabIndex: 0
  },
})

2.在 custom-tab-bar/index.js 中设置

//custom-tab-bar/index.js

const app = getApp()


lifetimes: {

    attached() {

      this.setData({
        selected: app.globalData.tabIndex
      })

    }

},

methods: {

    switchTab(e) {

      const data = e.currentTarget.dataset

      const url = data.path

      wx.switchTab({ url })

      app.globalData.tabIndex = data.index
    }
},

3.每个tabbar页面设置


    if (typeof this.getTabBar === 'function' && this.getTabBar()) {
      this.getTabBar().setData({
        selected: // tabbar的id 
      })
    }

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值