微信小程序-自定义tabBar
创始人
2024-11-19 13:36:01
0

通过官网给出的示例自己实现了自定义的tabBar,但结果发现

无法监听页面生命周期函数

结语:原想的是实现不一样的效果(如下)

故尝试了自定义tabBar,虽然做出来了,但也发现这个做法存在不足:

在页面js文件中,需要给出以下代码:

Component({   pageLifetimes: {     show() {       if (typeof this.getTabBar === 'function' &&         this.getTabBar()) {         this.getTabBar().setData({           selected: 0		// 对应tabBar的下标         })       }     }   },   data: {     navBarHeight: getApp().globalData.navBarHeight,   }, })

相当于将原来的page页面更改为组件components

这样做的结果就是无法监听页面生命周期函数(至少在创建page时自带的生命周期函数均无法监听)

这是我遇到的,若有解决方案,欢迎留言告知

实现步骤

官方文档:基础能力 / 自定义 tabBar (qq.com)

1.app.json配置tabBar

"tabBar": {     "custom": true,     "color": "#a5abbd",     "selectedColor": "#1dba73",     "backgroundColor": "#ffffff",     "list": [{       "pagePath": "pages/home/home",       "text": "首页"     },{       "pagePath": "pages/index/index",       "text": "测试"     }]   }

注意:此处path不写最前面的 /

2.在项目根目录下添加文件夹custom-tab-bar,并添加组件,命名为index(下面的代码均借鉴官方demo,可自行修改)

项目文件夹如下:

index.js:

Component({   data: {     selected: 0,     color: "#a5abbd",     selectedColor: "#1dba73",     list: [{       pagePath: "/pages/home/home",       iconPath: "/images/icon/home.svg",       selectedIconPath: "/images/icon/home-selected.svg",       text: "首页"     }, {       // 此处path必须加前面的/,否则在切换tabbar时,会自动拼接地址,导致传入url有误,系统没有任何效果       pagePath: "/pages/index/index",       text: "测试"     }]   },    methods: {     switchTab(e) {       const data = e.currentTarget.dataset       const url = data.path       // wx.switchTab切换tabBar组件,可传入url,success,fail,此处简写       wx.switchTab({url})       // 完整写法       // wx.switchTab({       //   url: url,       //   success(res){console.log(res)},       //   fail(error){console.log(error)}       // })       this.setData({         selected: data.index       })     }   } })

注意:此处path必须加前面的/,否则在切换tabbar时,会自动拼接地址,导致传入url有误,系统没有任何效果

index.json:

{   "component": true }

index.wxml:

      {list}}" wx:key="index" class="tab-bar-item" data-path="{{item.pagePath}}" data-index="{{index}}" bindtap="switchTab">     {selected === index ? item.selectedIconPath : item.iconPath}}">     {selected === index ? selectedColor : color}}">{{item.text}}    

index.wxss:

.tab-bar {   position: fixed;   bottom: 0;   left: 0;   right: 0;   height: 48px;   background: white;   display: flex;   padding-bottom: env(safe-area-inset-bottom); }  .tab-bar-border {   background-color: rgba(0, 0, 0, 0.33);   position: absolute;   left: 0;   top: 0;   width: 100%;   height: 1px;   transform: scaleY(0.5); }  .tab-bar-item {   flex: 1;   text-align: center;   display: flex;   justify-content: center;   align-items: center;   flex-direction: column; }  .tab-bar-item image {   width: 27px;   height: 27px; }  .tab-bar-item view {   font-size: 10px; }

到此处应该就会出现tabBar且可点击,点击时也能切换页面

但可能出现问题:一个tabBar要点击两次才能更改样式(即tabBar与页面未连接)

解决:

在页面的js文件中:

Component({   pageLifetimes: {     show() {       if (typeof this.getTabBar === 'function' &&         this.getTabBar()) {         this.getTabBar().setData({           selected: 0		// 对应tabBar的下标         })       }     }   },   data: {     navBarHeight: getApp().globalData.navBarHeight,   }, })

至此,自定义tabBar便完成了,但就像我前面说的,如此修改之后,无法监听页面的生命周期函数,大家自行判断是否需要自定义tabBar,或者有更好解决方案的,欢迎评论区交流

相关内容

热门资讯

查到实测!中至余干小程序破解,... 查到实测!中至余干小程序破解,多乐手游辅助软件,透牌教程(有挂方略)是一款可以让一直输的玩家,快速成...
揭秘真相“人皇辅助软件下载”介... 您好:人皇辅助软件下载这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌...
盘点十款!湛江吴川0759程序... 您好,雀友会万能辅助器这款游戏可以开挂的,确实是有挂的,需要了解加微【485275054】很多玩家在...
避坑细节“暗宝辅助好用”解谜开... 避坑细节“暗宝辅助好用”解谜开挂作弊辅助软件(好像是真的有挂);1、这是跨平台的暗宝辅助好用黑科技,...
最新通报!老友跑得快辅助小说最... 最新通报!老友跑得快辅助小说最新章节,功夫川麻辅助,规律教程(有挂分析)是一款可以让一直输的玩家,快...
9分钟了解“菠萝辅助器免费版的... 9分钟了解“菠萝辅助器免费版的功能介绍”科普开挂作弊辅助工具(原来真的是有挂);菠萝辅助器免费版的功...
分享一款!微信开发辅助工具,钱... 分享一款!微信开发辅助工具,钱塘十三水可以开挂辅助,大神讲解(有挂秘籍)是一款可以让一直输的玩家,快...
揭秘攻略“玉海楼茶苑辅助工具”... 揭秘攻略“玉海楼茶苑辅助工具”推荐开挂作弊辅助器(一直真的有挂);玉海楼茶苑辅助工具中的10万兆豆可...
玩家必备攻略!欢聚水鱼辅助插件... 玩家必备攻略!欢聚水鱼辅助插件,闽游app破解,技巧教程(有挂分析);1、让任何用户在无需AI插件第...
最新技巧“微信边锋辅助”讲解开... 【福星临门,好运相随】;最新技巧“微信边锋辅助”讲解开挂作弊辅助器(总是是有挂);暗藏猫腻,小编详细...