微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)

文章目录

      • 背景
      • 实现步骤:
        • 1、我们先在utils目录中创建tab-service.js文件,写上全局的数据及方法;
        • 2、在app.json文件中配置导航信息
        • 3、根目录下创建custom-tab-bar目录
        • 4、编写custom-tab-bar组件
          • 4.1、custom-tab-bar/index.wxml
          • 4.2、custom-tab-bar/index.js
          • 4.3、custom-tab-bar/index.wxss
          • 4.4、custom-tab-bar/index.json
        • 5、登录页面获取角色(pages/index.js)
        • 6、对应tab页面(pages/index1.js)
        • 7、项目整体目录
        • 8、实现后的效果
        • 8、示例代码

背景

在开发小程序过程中,有个需求是,小程序底部的tabBar需要根据不同用户角色显示不同底部导航。此时就需要用到自定义底部导航 custom-tab-bar。

上次发文是组合显示4个底部tabBar导航,很多小伙伴评论说组合超过5个怎么办。他们的需求总数超过5个了。

现在我在这里更新一下。
1、实现自由组合tabBar菜单项目,支持自由组合总数超过5个tabBar菜单。
2、本示例是7个底部导航,分2种权限,权限1显示1,2,3;权限2显示4,5,6,7;
3、当然你也可以自由其他组合,比如:权限1显示1,4;权限2显示1,2,3,4;
4、本示例只是提供了思路及方法,你可以自由扩展。

实现步骤:

1、我们先在utils目录中创建tab-service.js文件,写上全局的数据及方法;
// tabBar的data
let tabData = {tabIndex: 0,//底部按钮高亮下标tabBar: {custom: true,color: "#5F5F5F",selectedColor: "#07c160",backgroundColor: "#F7F7F7",list: []}
}// 更新菜单
const updateRole = (that, type) => {//这里设置权限(分2种权限,权限1显示1,2,3;权限2显示4,5,6,7;)if (type === '0') {tabData.tabBar.list=[{"pagePath": "pages/index1","iconPath": "/image/icon_component.png","selectedIconPath": "/image/icon_component_HL.png","text": "按钮1"},{"pagePath": "pages/index2","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮2"},{"pagePath": "pages/index3","iconPath": "/image/icon_component.png","selectedIconPath": "/image/icon_component_HL.png","text": "按钮3"},]}else if (type === '1'){tabData.tabBar.list=[{"pagePath": "pages/index4","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮4"},{"pagePath": "pages/index5","iconPath": "/image/icon_component.png","selectedIconPath": "/image/icon_component_HL.png","text": "按钮5"},{"pagePath": "pages/index6","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮6"},{"pagePath": "pages/index7","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮7"}]} updateTab(that);
}// 更新底部高亮
const updateIndex = (that, index) => {tabData.tabIndex = index;updateTab(that);
}// 更新Tab状态
const updateTab = (that) => {if (typeof that.getTabBar === 'function' && that.getTabBar()) {that.getTabBar().setData(tabData);}
}// 将可调用的方法抛出让外面调用
module.exports = {updateRole, updateTab, updateIndex,tabBar:tabData.tabBar.list
}
2、在app.json文件中配置导航信息
{"pages": ["pages/index","pages/index1","pages/index2","pages/index3","pages/index4","pages/index5","pages/index6","pages/index7"],"tabBar": {"custom": true,"color": "#5F5F5F","selectedColor": "#07c160","borderStyle": "black","backgroundColor": "#F7F7F7","list": [{"pagePath": "pages/index1","iconPath": "/image/icon_component.png","selectedIconPath": "/image/icon_component_HL.png","text": "按钮1"},{"pagePath": "pages/index2","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮2"},{"pagePath": "pages/index3","iconPath": "/image/icon_component.png","selectedIconPath": "/image/icon_component_HL.png","text": "按钮3"},{"pagePath": "pages/index4","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮4"},{"pagePath": "pages/index5","iconPath": "/image/icon_component.png","selectedIconPath": "/image/icon_component_HL.png","text": "按钮5"},{"pagePath": "pages/index6","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮6"},{"pagePath": "pages/index7","iconPath": "/image/icon_API.png","selectedIconPath": "/image/icon_API_HL.png","text": "按钮7"}]},"window": {"backgroundTextStyle": "light","navigationBarBackgroundColor": "#fff","navigationBarTitleText": "WeChat","navigationBarTextStyle": "black"}
}

注意:“custom”: true是重点,默认是没有这个字段的,在配置项中新增即可;
这里不用管tabBar的list超过5个,因为后面是使用自定义组件,完全接管 tabBar 的渲染

3、根目录下创建custom-tab-bar目录
custom-tab-bar/index.js
custom-tab-bar/index.json
custom-tab-bar/index.wxml
custom-tab-bar/index.wxss
4、编写custom-tab-bar组件

用自定义组件的方式编写即可,该自定义组件完全接管 tabBar 的渲染。

4.1、custom-tab-bar/index.wxml
<!--miniprogram/custom-tab-bar/index.wxml-->
<view class="tabBar"><view class="tabBarItem" wx:for="{{tabBar.list}}" wx:key="index" data-path="{{'/' + item.pagePath}}" data-index="{{index}}" bindtap="switchTab"><image class="itemImage" src="{{tabIndex === index ? item.selectedIconPath : item.iconPath}}"></image><view class="itemTitle" style="color: {{tabIndex === index ? tabBar.selectedColor : tabBar.color}}">{{item.text}}</view></view>
</view>

其中tabBar就是在tab-service.js文件中写的公共数据。

4.2、custom-tab-bar/index.js
Component({data: {},methods: {switchTab(event) {// data为接受到的参数const data = event.currentTarget.dataset;// 取出参数中的path作为路由跳转的目标地址wx.switchTab({url: data.path});},}
})
4.3、custom-tab-bar/index.wxss
.tabBar {position: fixed;bottom: 0;left: 0;right: 0;height: 48px;background: white;display: flex;padding-bottom: env(safe-area-inset-bottom);border-top: 1px solid #c1c1c1;
}.tabBarItem {flex: 1;text-align: center;display: flex;justify-content: center;align-items: center;flex-direction: column;
}.itemImage {width: 26px;height: 26px;
}.itemTitle {font-size: 10px;
}
4.4、custom-tab-bar/index.json
{"component": true
}
5、登录页面获取角色(pages/index.js)
// 全局tab-service.js,引入一下
const tabService = require("../utils/tab-service")/**
* 生命周期函数--监听页面加载
*/
onLoad(options) {//这里设置权限(0:显示1,2,3导航3个按钮,1:显示4,5,6,7导航4个按钮)//当然你也可以自由其他组合,比如:权限1显示1,4;权限2显示1,2,3,4;//注意你的index下标,及不同权限第一个页面的跳转路径//以下是0tabService.updateRole(this, '0')wx.switchTab({url:'/pages/index1'})//以下是1,从4开始// tabService.updateRole(this, '1')// wx.switchTab({//   url:'/pages/index4'// })
},
6、对应tab页面(pages/index1.js)
// 全局tab-service.js,引入一下
const tabService = require("../utils/tab-service");/**
* 生命周期函数--监听页面显示
*/
onShow() {//更新底部高亮tabService.updateIndex(this, 0)
},

其他几个tabBar页面也是一样,每个导航对一个页面,0,1,2,3以此类推即可;
注意你的index下标,及不同权限页面里面对应的高亮下标设置。

7、项目整体目录

在这里插入图片描述

8、实现后的效果

1种权限显示3个按钮(这里做的是显示1,2,3导航)

在这里插入图片描述

另1种权限显示4个按钮(这里做的是显示4,5,6,7导航)

在这里插入图片描述

8、示例代码

相关的示例代码已经上传,可以到顶部下载下来运行查看效果。

修改好权限后,记得要重新编译哦。

其他需求或问题可以评论留言。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3031752.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

政务网离线安装python3及其依赖手册

文章目录 python安装及环境配置gcc安装make安装python3安装pip安装 测试测试python3报错:ModuleNotFoundError: No module named _ctypes’测试pip3报错“pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available.” 依赖库…

项目经理有哪些常见的沟通技巧?

项目经理有哪些常见的沟通技巧&#xff1f; 项目管理的核心之一是沟通。有效的沟通技巧对于确保项目团队成员之间的合作、项目信息的准确传达以及项目目标的顺利实现至关重要。一个号的项目管理工具可以让我们事半功倍&#xff0c;结合项目管理工具zz-plan 来探讨一些项目经理…

2024年第九届数维杯大学生数学建模挑战赛C 题解题思路1.0版本

题目分析&#xff1a; 问题背景&#xff1a;天然气水合物作为一种高效的清洁后备能源&#xff0c;其资源量评估对未来能源开发极为重要。 具体任务&#xff1a; 0.数据预处理 首先将txt中的数据合并到表格里方便后续操作&#xff0c;从Excel文件导入数据&#xff0c;清洗数…

【机器学习】逻辑回归:智能垃圾邮件分类实例

逻辑回归&#xff1a;智能垃圾邮件分类的利器 一、引言二、逻辑回归概述三、垃圾邮件分类实例数据准备特征选择与建模 四、总结与展望 一、引言 随着互联网的迅猛发展&#xff0c;电子邮件已成为人们日常生活和工作中不可或缺的一部分。然而&#xff0c;与此同时&#xff0c;垃…

综合能力 | 误差 | 学习笔记

误差指真值与观测值的差值。 误差分为系统误差&#xff08;消除方法&#xff1a;观测方法、仪器校正、修正等&#xff09;、偶然误差&#xff08;符合正态分布规律&#xff0c;进行计算纠正&#xff09;、粗差&#xff08;一般舍弃&#xff09;。 中误差&#xff08;均方差或标…

如何用 OceanBase做业务开发——【DBA从入门到实践】第六期

当应用一款新的数据库时&#xff0c;除了基础的安装部署步骤&#xff0c;掌握其应用开发方法才是实现数据库价值的关键。为此&#xff0c;我们特别安排了5月15日&#xff08;周三&#xff09;的《DBA 从入门到实践》第六期课程——本次课程将带大家了解OceanBase数据库的开发流…

探索静态住宅IP代理:保障网络安全与隐私的新途径

在数字化时代&#xff0c;互联网已经成为人们日常生活和工作的重要组成部分。然而&#xff0c;网络安全和隐私保护问题也随之而来&#xff0c;成为广大网民关注的焦点。静态住宅IP代理作为一种新兴的网络技术&#xff0c;以其独特的功能和优势&#xff0c;逐渐受到用户的青睐。…

IIS配置SSL,根据pem和key生成pfx,openssl的版本不能太高

1、生成pfx文件 供应商给的文件是pef和key后缀的两个文件&#xff0c;在IIS里不好导入(如果有知道好导入的可以给我留言&#xff0c;谢谢。)。 1.1 下载OpenSSL工具&#xff0c;并安装。 主要用于将.pem文件转成.pfx文件。 下载OpenSSL的链接&#xff1a;http://slproweb.com/…

【科学研究】秒懂C刊|微信不只是工具更重新定义了生活‼️ 摘 要:存在现象学的技术论,打破了现有新媒

::: block-1 “时问桫椤”是一个致力于为本科生到研究生教育阶段提供帮助的不太正式的公众号。我们旨在在大家感到困惑、痛苦或面临困难时伸出援手。通过总结广大研究生的经验&#xff0c;帮助大家尽早适应研究生生活&#xff0c;尽快了解科研的本质。祝一切顺利&#xff01;—…

【020】基于JavaWeb实现的批报管理系统

项目介绍 基于jspservlet实现的批报管理系统采用B/S架构,该项目设计了一个角色管理员&#xff0c;管理员实现了我的案件、查询统计、项目维护等三大功能模块 技术栈 开发工具&#xff1a;Idea2020.3 运行环境&#xff1a;jdk1.8tomcat9.0mysql5.7 服务端技术&#xff1a;j…

1.基于python的单细胞数据预处理-特征选择

文章目录 特征选择背景基于基因离散度基于基因归一化方差基于基因皮尔森近似残差特征选择总结 参考&#xff1a; [1] https://github.com/Starlitnightly/single_cell_tutorial [2] https://github.com/theislab/single-cell-best-practices 特征选择背景 现在已经获得了经过…

Python之数据分析基础

导言&#xff1a; “21世纪的竞争是数据的竞争&#xff0c;谁掌握数据&#xff0c;谁就掌握未来”。如何将大量看似杂乱无章的数据进行聚合&#xff0c;并发现潜在的规律也变得越来越重要。本文将先说明数据分析的步骤&#xff0c;再通过python完成实例数据的处理、分析最终展…

针对 % 号 | 引起的 不安全情况

把网站开放的课程都检索下来了 一、情况1 org.apache.tomcat.util.http.Parameters processParameters 信息: Character decoding failed. Parameter [Mac] with value [%%%] has been ignored. Note that the name and value quoted here may be corrupted due to the failed…

【北京迅为】《iTOP-3588从零搭建ubuntu环境手册》-第4章 Ubuntu20.04支持中文

RK3588是一款低功耗、高性能的处理器&#xff0c;适用于基于arm的PC和Edge计算设备、个人移动互联网设备等数字多媒体应用&#xff0c;RK3588支持8K视频编解码&#xff0c;内置GPU可以完全兼容OpenGLES 1.1、2.0和3.2。RK3588引入了新一代完全基于硬件的最大4800万像素ISP&…

电商购物系统商品数据结构设置

电商购物系统商品数据结构设置 如上图所示 , 该表为商品表关系的示意图 , 气质我们要溥仪一个电视购物系统要用到的知识那就是SPU和SKU 简单来说这两种就是不同的分类方式 , 我们在浏览淘宝等页面的时候也会遇见相同的情况如我们可以进行品牌的筛选 , 也可以进行商品价格的筛选…

C# WinForm —— 13 ComboBox下拉框/组合框介绍

1. 简介 ComboBox 是由 textBox 和 listBox 组合而成的&#xff0c;只能选择一项&#xff0c;不能选择多项&#xff0c;其他功能和 listBox类似 ComboBox 下拉框的三种样式&#xff1a;&#xff08;通过 DropDownStyle属性 设置&#xff09; Simple: 最简单的样式&#xff0c…

YOLO系列笔记(十四)——Compute Canada计算平台及其常见命令介绍

Compute Canada平台及其常见命令介绍 前言优势使用方法1. 检查模块不带版本号带版本号 2. 加载模块3. 检查模块是否加载成功4. 创建虚拟环境5. 编写作业脚本6. 提交作业7. 监控作业状态8. 查看作业开始预计时间9. 查看作业的详细输出10. 取消作业 注意结语 前言 大家好&#x…

QML 本地存储(Setting,sqlite)

Qt hello - 专注于Qt的技术分享平台 QML 原生的储存方有两种&#xff1a; 1&#xff0c;Settings 跟QWidget 中的QSettings 一样&#xff0c;可以简单的存储一些配置。 2&#xff0c;Sqlite sqlite数据库。可以存储一些复杂的数据。 一&#xff0c;Settings 我们以一个按钮的位…

揭秘微服务架构:十大设计模式助力企业数字化转型

微服务架构中10个常用的设计模式 微服务是一种架构风格&#xff0c;它将一个复杂的应用拆分成多个独立自治的服务&#xff0c;每个服务负责应用程序中的一小部分功能。这些服务通过定义良好的API进行通信&#xff0c;通常是HTTP RESTful API或事件流。微服务架构的主要特点包括…

【SpringSecurity源码】过滤器链加载流程

theme: smartblue highlight: a11y-dark 一、前言及准备 1.1 SpringSecurity过滤器链简单介绍 在Spring Security中&#xff0c;过滤器链&#xff08;Filter Chain&#xff09;是由多个过滤器&#xff08;Filter&#xff09;组成的&#xff0c;这些过滤器按照一定的顺序对进…