uniapp根据登录用户的角色动态的改变tabBar的数量和内容
此文章借鉴于https://blog.csdn.net/fuyuumiai/article/details/109746357,在此基础上修改小部分内容,适用于我这种uniapp小白
介绍:
现在我们要满足的项目需求是根据登录用户角色的不同,tabBar的数量和内容显示不同,如下图
用户角色为管理员时:

用户角色为普通用户时:

登录用户的角色不同,因为权限不同所以tabBar的内容和数量也不同,而uniapp中tabBar本身的配置 uni.setTabBarItem(OBJECT) 只能够满足动态设置 tabBar 某一项的内容,没办法实现上图中的需求
这个时候我们就可以使用UI框架Uview来实现需求
一、uVIew的下载及配置
大家可以直接去官网根据官方指导下载配置 uView
官方推荐两种安装方式,一种是下载安装,一种是npm安装,我个人选择了第一种,现在讲下我个人的配置过程(可以直接看官网的讲的很详细)
下载
打开uView的下载地址 https://ext.dcloud.net.cn/plugin?id=1593 选择右侧的用HbuilderX导入插件

导入时会新建一个文件夹用来存放uView文件确认好路径后直接点击创建就可以

下载成功后,找到新建的文件夹,下载好的uView文件就在里面,把该文件夹内的uview-ui文件复制到uniapp项目的根目录下

配置
配置项官方写的很详细, 配置
1、确认项目中已经安装好scss插件,在配置uview的css时需要用到
2、在main.js中引入uview的js库
import uView from 'uview-ui'
Vue.use(uView)
3、在项目根目录的uni.scss文件中引入 uView的全局SCSS主题文件,在uni.scss文件的最开始引入就可以,方便查找

4、在app.vue文件的style样式中引入uView基础样式,style中需要写明 lang = scss ,我之前就已经配置好了scss插件,所以直接用就可以,没有安装scss插件的自行安装

5、配置easycom组件模式
在根目录的page.json文件中配置,意思是 // 匹配uview-ui文件下components目录内的vue文件,具体解释可以查看官网 easycom
"easycom": {
"^u-(.*)": "@/uview-ui/components/u-$1/u-$1.vue"
}

至此,uview的安装配置结束
二、配置tabBar
1、创建tabBar页面

2、在page.json配置tabBar页面路径
在page.json中配置tabBar页面路径,只需要配置各个页面的路径就可以,不用配置其他项

3、创建自定义tabBar文件
在项目根目录下创建untils文件夹,文件夹内创建tabBer.js文件

这个js文件是我们自定义的tabBar属性文件,用来覆盖原来的配置

根据uniapp官网中tabBar的属性配置即可,每个数组代表一种角色要显示的tabBar列表,比如我有管理员和普通用户两种角色,就配置两个数组,每个数组里面配置各自tabBar的页面属性,就算两个角色有相同的页面,也要在各自的数组中配置,
数组中的顺序就是tabBar显示的顺序,对顺序有要求的请注意此项
三、配置vuex
uniapp中已经集成了vuex,我们直接用就可以,
我个人对vuex并不太了解,在项目中只是能单纯的运用,getters.js 和index.js完全是套我个人理解的模板来做
1、根目录下创建store文件夹及其他文件

2、配置tabber.js文件
在tabBer.js文件中对登录用户进行角色判断
midBtn是为了判断uview中tabBar组件的加号按钮是否显示,当你的项目需求为确认显示或确认不显示时,直接在uview/components/u-tabbar中找到该项修改属性为true或者false即可,不用再在tabBer.js文件中判断,我的项目不需要,所以我会把这一项直接删掉

3、getters
当tabBer.js文件中的midBtn去掉不写时,本文件中的对应项也直接去掉

4、index.js

5、mian.js引入store
在main.js中引入store文件


四、引入组件
在每个tabBar的页面引入uView中的tabBar组件,父传子传值,一些固定的值可以不传值直接在组件中修改

这是tabbar组件,uview-ui/components/u-tabbar.vue,props中的值如果不需要动态变化可以直接设定初始值,父组件不再传值,
如下图,直接设置组件中间的加号按钮为false,前面一系列关于midBtn的代码都可以删除

结束!!!
撒花!!!
uniapp根据登录用户的角色动态的改变tabBar的数量和内容的更多相关文章
- 关于在vuejs中动态加载不确定数量和内容的组件的解决方案
在做一个门户项目的时候,客户要求需要进行私人化定制,每个人进入首页的时候可以自定义首页显示的版块 要在4.50个组件中显示随机N个组件按照每个人选定的顺序排列.需求说完了,接下来说说解决方案: htm ...
- springBoot+springSecurity 数据库动态管理用户、角色、权限
使用spring Security3的四种方法概述 那么在Spring Security3的使用中,有4种方法: 一种是全部利用配置文件,将用户.权限.资源(url)硬编码在xml文件中,已经实现过, ...
- springBoot+springSecurity 数据库动态管理用户、角色、权限(二)
序: 本文使用springboot+mybatis+SpringSecurity 实现数据库动态的管理用户.角色.权限管理 本文细分角色和权限,并将用户.角色.权限和资源均采用数据库存储,并且自定义滤 ...
- spring security 动态 修改当前登录用户的 权限
1.前言 spring security 可以获取当前登录的用户信息,同时提供了接口 来修改权限列表信息 , 使用这个方法 ,可以动态的修改当前登录用户权限. 那么问题来了... 如果我是管理员 ,如 ...
- [转]Sql Server 2005中的架构(Schema)、用户(User)、登录(Login)和角色(Role)
每一个概念的产生必然是因为碰到了无法解决的问题.换句话说,如果没有它,必然会导致某些问题难以解决.所以我想从这个角度切入,希望能把这几个复杂而暧昧的多角关系从最实用的角度来阐述清楚. 在问题的最初,我 ...
- SQL SERVER服务器登录名、角色、数据库用户、角色、架构的关系
原创链接:https://www.cnblogs.com/junfly/articles/2798023.html SQL SERVER 基础教程中关于服务器登录名.服务器角色.数据库用户.数据库角色 ...
- SQL SERVER 2008 服务器登录名、角色、数据库用户、角色、架构的关系
sql server登录名.服务器角色.数据库用户.数据库角色.架构区别联系 1.一个数据库用户可以对应多个架构(架构是表容器).架构里面包含的是数据库表. 2.一个数据库角色有可能涉及多个架构.数据 ...
- SQL Server 登录名、用户、角色与权限
1.在SQL Server中,用户和角色是分为服务器级别和数据库级别的 2.服务器级别 登录名:指有权限登录到某服务器的用户,例如超级管理员的登录名是sa: 登录名具体位置在 数据库——>安全 ...
- (一)shiro简介和用户登录demo及角色管理
一.shiro简介 Apache Shiro是Java的一个安全框架.Shiro可以非常容易的开发出足够好的应用,其不仅可以用在JavaSE环境,也可以用在JavaEE环境.Shiro可以帮助我们完成 ...
随机推荐
- 探究虚拟dom与diff算法
一.虚拟DOM (1)什么是虚拟DOM? vdom可以看作是一个使用javascript模拟了DOM结构的树形结构,这个树结构包含整个DOM结构的信息,如下图: 可见左边的DOM结构,不论是标签名 ...
- 利用设计模式消除业务代码中的 if-else
准备工作:假设这样的一个业务场景:有一个自动开票的功能需要实现,在程序里面需要根据账单的类型执行对应的处理逻辑. 以下使用了 Lombok 简化代码!!! 账单类型枚举: /** * @author ...
- Vue2+Koa2+Typescript前后端框架教程--04班级管理示例(路由调用控制器)
上篇文章分享了简单的三层模式和基础文件夹的创建,本篇将以示例的形式详细具体的展示Router.Controller.Service.Model之间业务处理和数据传输. 1. 班级管理数据模型创建.数据 ...
- Qt学习笔记-Qt-4.8.6+phonon+mplayer
首先,用phonon播放音乐时,可以使用mplayer.首先,你的设备上需要安装一个mplayer并测试能用. 然后安装后端播放插件. 我用的是网上找的phonon-mplayer. 按照网上的方法, ...
- 对象存储Backblaze B2作为ShareX图床的Windows及安卓端配置
标题: 对象存储Backblaze B2作为ShareX图床的Windows及安卓端配置 作者: 梦幻之心星 sky-seeker@qq.com 标签: [对象存储,图床,Backblaze,Shar ...
- Java学习日报8..4
class ArrayUtil{ public static void reverse(int data[]) { int center=data.length/2; int head=0; int ...
- TurtleBot3使用课程-第二节b(北京智能佳)
目录 1.导航 2 1.1 运行导航节点 3 1.1.1 [远程PC]运行roscore 3 1.1.2 [turtlebot3 SBC]运行提出turtlebot3 3 1.1.3[远程PC]运行导 ...
- day121:MoFang:植物的状态改动(幼苗→成长期)&植物的浇水功能
目录 1.当果树种植以后在celery的异步任务中调整浇水的状态 2.客户端通过倒计时判断时间,显示浇水道具 3.客户端判断当前种植物状态控制图标的显示和隐藏 4.当用户单击浇水图标, 则根据当前果树 ...
- ACL技术(访问控制列表)
• Access Control List • 访问控制列表 • 是一种包过滤技术 • ACL基于IP包头的IP地址.四层TCP/UDP头部的端口号.[五层数据]进行过滤 • ...
- 剑指offer 面试题9:用两个栈实现队列
题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 使用栈实现队列的下列操作:push(x) -- 将一个元素放入队列的尾部.pop() -- 从队列首部移 ...