视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
微信小程序开发之自定义tabBar的实现
2020-11-27 22:08:11 责编:小采
文档


最近开发微信小程序,公司要求做一个类似闲鱼的tabbar,但是网上大多资料的tabbar都会在页面切换的时候重新渲染,所以我写了一个不会重新渲染的tabbar,有需要的直接拿走不谢。https://github.com/SuRuiGit/wxapp-customTabbar

在小程序的开发文档中,对tabbar是这样说明的:

如果小程序是一个多 tab 应用(客户端窗口的底部或顶部有 tab 栏可以切换页面),可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页面。

Tip:

1.当设置 position 为 top 时,将不会显示 icon

2.tabBar 中的 list 是一个数组,只能配置最少2个、最多5个 tab,tab 按数组的顺序排序。

在实际开发过程中,小程序自带的tabbar样式并不能满足设计提供的开发需求,所以需要我们自定义一套属于自己的tabbar。

使用步骤如下:

第一步:找到项目中的tabbarComponent目录,拷贝到你的工程中,然后将tabbarComponent->icon图标替换成你自己的tabbar图片

第二步:到app.json中配置tabBar,这里我就不细说了,只强调闲鱼的tabbar中间的按钮是跳到二级页面,所以不配置在tabBar的list中

第三步:在app.js的onLaunch方法中调用wx.hideTabBar();隐藏系统自带的tabBar

第四步:在app.js中的globalData中加入自定义tabbar的参数,再加入一个方法给tabBar.list配置中的页面使用,代码如下

globalData: {
 userInfo: null,
 tabBar: {
 "backgroundColor": "#ffffff",
 "color": "#979795",
 "selectedColor": "#1c1c1b",
 "list": [
 {
 "pagePath": "/page/index/index",
 "iconPath": "icon/icon_home.png",
 "selectedIconPath": "icon/icon_home_HL.png",
 "text": "首页"
 },
 {
 "pagePath": "/page/myRelease/index",
 "iconPath": "icon/icon_release.png",
 "isSpecial": true,
 "text": "发布"
 },
 {
 "pagePath": "/page/mine/index",
 "iconPath": "icon/icon_mine.png",
 "selectedIconPath": "icon/icon_mine_HL.png",
 "text": "我的"
 }
 ]
 }
 }
editTabbar: function() {
 let tabbar = this.globalData.tabBar;
 let currentPages = getCurrentPages();
 let _this = currentPages[currentPages.length - 1];
 let pagePath = _this.route;
 (pagePath.indexOf('/') != 0) && (pagePath = '/' + pagePath);
 for (let i in tabbar.list) {
 tabbar.list[i].selected = false;
 (tabbar.list[i].pagePath == pagePath) && (tabbar.list[i].selected = true);
 }
 _this.setData({
 tabbar: tabbar
 });
 },

第五步:在tabBar的list中配置的页面的.js文件的data中加入tabbar:{},并在onload方法中调用app.editTabbar();

第六步:在tabBar的list中配置的页面的.json文件中加入

"usingComponents": {

"tabbar": "../../tabbarComponent/tabbar"

}

在.wxml文件中加入<tabbar tabbar="{{tabbar}}"></tabbar>

到目前为止,自定义tabbar就完成啦,撒花!!!!!

下载本文
显示全文
专题