uniapp开发小程序,如何根据权限动态配置按钮或页面内容

前言

写了好几个项目,发现小程序对权限控制非常麻烦,于是有了这个想法,但是网上找了一圈没有一个比较完善的讲解,因为小程序不支持自定义指令,所以不能像后台那样方便,于是就将几个博主的想法结合。
思路就是v-if或者v-show,封装一个方法就行了。

使用方法

1.写权限验证js

找个地方建一个js文件,写权限验证函数,如下
注:代码验证的前提是将权限列表存储在缓存中了,所以我直接取出来验证。如有其他逻辑请自行更改。 至于权限列表从哪里来,就不在赘述了。

javascript 复制代码
import userStore from "../store/userStore.js"

// 验证用户是否含有指定权限,只需包含其中一个
export function auth(authList){
	return authList.some((item) => {
	  return verifySingleAuth(item);
	});
}

// 验证用户是否含有指定权限,必须全部拥有
export function authAll(authList){
	return authList.every((item) => {
	  return verifySingleAuth(item);
	});
}

//验证权限
function verifySingleAuth(permission){
	const store = userStore();
	const all_permission = '*:*:*';	//所有权限标识
	const permissions = store.permissions;
	if (permission && permission.length > 0) {
	  return permissions.some((v) => {
	    return all_permission === v || v === permission;
	  });
	} else {
	  return false;
	}
}

2.main.js中注册为全局变量(函数)

贴上代码

javascript 复制代码
	app.config.globalProperties.$auth=auth
	app.config.globalProperties.$authAll=authAll

3.页面中直接使用

缓存中的权限为'aa:*:*'

html 复制代码
<template>
	<view class="content">
		测试一验证结果:{{$auth(['aa:*:*','bb:*:*'])}}
		<view v-show="$auth(['aa:*:*','bb:*:*'])">
			<uv-button type="primary" shape="circle" text="按钮"></uv-button>
		</view>
	</view>
</template>

缓存中的权限为'aa:*:*'

html 复制代码
<template>
	<view class="content">
		全部权限验证结果:{{$authAll(['aa:*:*','bb:*:*'])}}
		<view v-show="$authAll(['aa:*:*','bb:*:*'])">
			<uv-button type="primary" shape="circle" text="按钮"></uv-button>
		</view>
	</view>
</template>

搞定,示例中使用的是v-show,当然,使用v-if也是可以的,但是我发现,每当页面有值变化时,都会重复的调用,而且会调很多次,我猜测应该是数据变化,会重新渲染Dom,导致重复判断,可能会导致性能下降或者卡顿,所以我选择使用v-show。

相关推荐
2501_915909064 小时前
WebView 调试工具全解析,解决“看不见的移动端问题”
android·ios·小程序·https·uni-app·iphone·webview
说私域6 小时前
“开源链动2+1模式AI智能名片S2B2C商城小程序”在拉群营销中的应用与效果
人工智能·小程序
2501_915106326 小时前
App 怎么上架 iOS?从准备资料到开心上架(Appuploader)免 Mac 上传的完整实战流程指南
android·macos·ios·小程序·uni-app·iphone·webview
行走的陀螺仪8 小时前
uni-app + Vue3 实现折叠文本(超出省略 + 展开收起)
前端·javascript·css·uni-app·vue3
小禾青青8 小时前
uniapp安卓打包遇到报错:Uncaught SyntaxError: Invalid regular expression: /[\p{L}\p{N}]/
android·uni-app
环信即时通讯云9 小时前
实现小程序 uniApp 输入框展示自定义表情包
小程序·uni-app
特严赤傲9 小时前
uniappx 开发微信小程序 腾讯地图偏移量计算
微信小程序·uts·uniappx·地图偏移量
2501_9159214311 小时前
iOS 抓不到包怎么办?工程化排查与替代抓包方案(抓包/HTTPS/Charles代理/tcpdump)
android·ios·小程序·https·uni-app·iphone·tcpdump
星光一影11 小时前
打车/网约车、代驾、顺风车/拼车、货运、租车等多种出行服务的一站式解决方案
mysql·微信小程序·php·uniapp·html5·web app
黄交大彭于晏12 小时前
UniApp 全局通知功能实现
前端·vue.js·uni-app