uniapp Android解决 APP菜单、按钮权限控制方法
huangfuyk 人气:0【前言】
近日在开发一款使用uniapp做的APP时,遇到权限的控制需求,于是便采用如下方式进行校验(方法很多,只介绍这一种相对简单的)。
【方法】
示例代码如下
(仅供参考):
接口返回格式如下:
{ "id": "wms", "name": "首页", "url": "/pages/home-page/home-page", "children": [ { "id": "001", "name": "入库管理", "url": "/pages/storage-management/index", "children": [ { "id": "101", "name": "物料入库指令", "url": "/pages/storage-management/material/index", "children": [ { "id": "10101", "name": "新增" } ] }, { "id": "102", "name": "成品入库指令", "url": "/pages/storage-management/material/product-in/index", "children": [ { "id": "10201", "name": "新增" } ] } ] }, { "id": "002", "name": "出库管理", "url": "/pages/stock-preparation/index", "children": [ { "id": "201", "name": "物料出库指令", "url": "/pages/stock-preparation/material-out/index", "children": [ { "id": "20101", "name": "新增" } ] }, { "id": "202", "name": "成品出库指令", "url": "/pages/stock-preparation/product-out/index", "children": [ { "id": "20201", "name": "新增" } ] } ] } ] }
2.登陆成功后,调用接口:
①拿到的JSON数据转成一维数组;
②把每一项的id值取出,放进一个数组内;
③处理后的id数组,存到本地或者vuex。
//获取菜单权限 getMenu() { return new Promise((resolve, reject) => { this.$System.menu({systemSigns: 'app'}).then(res => { if (res.data.code === 0) { // 拿到的权限数据转成一维数组 let menuArrayList = flatten(res.data.data); // 把每一项的id值取出,放进一个数组内 let menuArray = []; menuArrayList.forEach(item => { menuArray.push(item.id); }); // id数组,存到本地 uni.setStorageSync('menuArray', menuArray); resolve(true) } }) }) }, //转成一维数组 flatten (arr){ return arr.reduce((result, item)=> { return result.concat(item,(Array.isArray(item.children) ? flatten(item.children) : [])); }, []); },
3.在项目utils文件夹或其他文件夹
下新建文件,例menuArr.js
内写如下内容(indexOf
或includes
均可):
export function menuPerm(id){ // 从本地缓存中异步获取menuArray的内容 let arr = uni.getStorageSync('menuArray'); return arrIndexOf(arr, id); } // 判断是否存在该权限 function arrIndexOf(arr, id) { if(arr.indexOf(id) !== -1){ return true; } else { return false; } }
4.在main.js
内引入menuArr.js
的方法menuPerm
,在原型上定义它们,使其在每个 Vue 的实例中均可用:
import {menuPerm} from './utils/menuArr.js' Vue.prototype.$menuPerm = menuPerm;
5.使用:v-show="$menuPerm( id )"
<button type="default" v-show="$menuPerm(20201)" @click="">新增</button>
加载全部内容