优雅实现微信小程序动态tabBar,根据不同用户角色显示不同底部导航——更新版(支持自由组合总数超过5个tabBar菜单)

背景

在开发小程序过程中,有个需求是,小程序底部的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://www.hqwc.cn/news/322245.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Nodejs】基于node http模块的博客demo代码实现

目录 package.json www.js db.js app.js routes/blog.js controllers/blog.js mysql.js responseModel.js 无开发&#xff0c;不安全。 这个demo项目实现了用Promise异步处理http的GET和POST请求&#xff0c;通过mysql的api实现了博客增删改查功能&#xff0c;但因没有…

Python 简单爬虫程序及其工作原理

前言 网络中包含大量的数据&#xff0c;这些数据对于我们来说是非常有价值的&#xff0c;因此编写一个爬虫程序&#xff0c;自动从网页中获取所需的数据&#xff0c;对于信息收集和分析是非常有帮助的。Python 是一种高效而灵活的编程语言&#xff0c;它提供了强大的库和框架来…

istio 限流:本地限流+全局限流

istio 限流在官网的位置是 任务->策略执行->使用 Envoy 启用速率限制 istio 限流基于数据面 Envoy 开发&#xff0c;Envoy 支持两个类型限流&#xff0c;分别是本地限流和全局限流&#xff08;本地限流和全局限流可以一起使用&#xff09; 开始之前 安装 istio部署 boo…

【面试高频算法解析】算法练习3 双指针

前言 本专栏旨在通过分类学习算法&#xff0c;使您能够牢固掌握不同算法的理论要点。通过策略性地练习精选的经典题目&#xff0c;帮助您深度理解每种算法&#xff0c;避免出现刷了很多算法题&#xff0c;还是一知半解的状态 专栏导航 二分查找回溯双指针滑动窗口深度优先搜索…

八、QLayout 用户基本资料修改(Qt5 GUI系列)

目录 一、设计需求 二、实现代码 三、代码解析 四、总结 一、设计需求 在很多应用程序中会有用户注册或用户编辑信息等界面。本文就设计一个用户信息编辑界面。要求包含用户名、姓名、性别、部门、年龄、头像、个人说明等信息。 二、实现代码 #ifndef DIALOG_H #define D…

STM32和ESP8266的WiFi模块控制与数据传输

基于STM32和ESP8266 WiFi模块的控制与数据传输是一种常见的嵌入式系统应用。在这种应用中&#xff0c;STM32作为主控制器负责控制和与外部传感器交互&#xff0c;而ESP8266 WiFi模块则用于实现无线通信和数据传输。本文将介绍如何在STM32上控制ESP8266模块&#xff0c;建立WiFi…

Ubuntu上使用node搭建本地静态http服务器

1.搭建步骤 1.安装Node.js。首先确保你的Ubuntu系统已经安装了Node.js。如果没有安装&#xff0c;可以通过以下命令进行安装&#xff1a; sudo apt-get update sudo apt-get install nodejs #安装nodejs 2.安装npm。npm是Node.js的包管理器&#xff0c;一般会随着Node.js一…

用开源大语言模型开发的智能对话机器人初版原型验证

用开源大语言模型开发的智能对话机器人初版原型验证 0. 背景1. 初版检证效果展示2. 验证效果总结 0. 背景 同事要想做一个智能对话机器人&#xff0c;特别的需求有有些几点&#xff0c; 通过预置提示词&#xff08;包括确认事项&#xff09;&#xff0c;让大语言模型用会话式…

react+AntDesign 之 pc端项目案例

1.环境搭建以及初始化目录 CRA是一个底层基于webpack快速创建React项目的脚手架工具 # 使用npx创建项目 npx create-react-app react-jike# 进入到项 cd react-jike# 启动项目 npm start2.安装SCSS SASS 是一种预编译的 CSS&#xff0c;支持一些比较高级的语法&#xff0c;…

如何搭建中后台管理系统

vue3 TS vite 搭建中后台管理系统 前言1、搭建步骤及方法2、集成多种插件功能&#xff0c;实现中后台按需使用3、新手学TS如何快速进入状态、定义TS类型4、layout搭建四款常见风格6、大屏搭建效果5、vue3Ts运营管理系统总结&#xff1a; 前言 要成功&#xff0c;先发疯&…

Python从入门到网络爬虫(面向对象详解)

前言 Python从设计之初就已经是一门面向对象的语言&#xff0c;正因为如此&#xff0c;在Python中创建一个类和对象是很容易的。本章节我们将详细介绍Python的面向对象编程。如果你以前没有接触过面向对象的编程语言&#xff0c;那你可能需要先了解一些面向对象语言的一些基本…

第二百四十六回

我们在上一章回中介绍了"修改页面导航中遇到的问题"沉浸式状态样相关的内容&#xff0c;本章回中将介绍如何修改Avatar的大小.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 概念介绍 我们在正常使用CirCleAvatar组件时可以通过该组件的radius属性来修改它的…