uniapp?Android解決?APP菜單、按鈕權(quán)限控制方法
【前言】
近日在開發(fā)一款使用uniapp做的APP時(shí),遇到權(quán)限的控制需求,于是便采用如下方式進(jìn)行校驗(yàn)(方法很多,只介紹這一種相對簡單的)。
【方法】
示例代碼如下(僅供參考):
接口返回格式如下:
{
"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.登陸成功后,調(diào)用接口:
①拿到的JSON數(shù)據(jù)轉(zhuǎn)成一維數(shù)組;
②把每一項(xiàng)的id值取出,放進(jìn)一個(gè)數(shù)組內(nèi);
③處理后的id數(shù)組,存到本地或者vuex。
//獲取菜單權(quán)限
getMenu() {
return new Promise((resolve, reject) => {
this.$System.menu({systemSigns: 'app'}).then(res => {
if (res.data.code === 0) {
// 拿到的權(quán)限數(shù)據(jù)轉(zhuǎn)成一維數(shù)組
let menuArrayList = flatten(res.data.data);
// 把每一項(xiàng)的id值取出,放進(jìn)一個(gè)數(shù)組內(nèi)
let menuArray = [];
menuArrayList.forEach(item => {
menuArray.push(item.id);
});
// id數(shù)組,存到本地
uni.setStorageSync('menuArray', menuArray);
resolve(true)
}
})
})
},
//轉(zhuǎn)成一維數(shù)組
flatten (arr){
return arr.reduce((result, item)=> {
return result.concat(item,(Array.isArray(item.children) ? flatten(item.children) : []));
}, []);
},3.在項(xiàng)目utils文件夾或其他文件夾下新建文件,例menuArr.js內(nèi)寫如下內(nèi)容(indexOf或includes均可):
export function menuPerm(id){
// 從本地緩存中異步獲取menuArray的內(nèi)容
let arr = uni.getStorageSync('menuArray');
return arrIndexOf(arr, id);
}
// 判斷是否存在該權(quán)限
function arrIndexOf(arr, id) {
if(arr.indexOf(id) !== -1){
return true;
} else {
return false;
}
}4.在main.js內(nèi)引入menuArr.js的方法menuPerm,在原型上定義它們,使其在每個(gè) Vue 的實(shí)例中均可用:
import {menuPerm} from './utils/menuArr.js'
Vue.prototype.$menuPerm = menuPerm;5.使用:v-show="$menuPerm( id )"
<button type="default" v-show="$menuPerm(20201)" @click="">新增</button>
到此這篇關(guān)于uniapp Android解決 APP菜單、按鈕權(quán)限控制方法的文章就介紹到這了,更多相關(guān)uniapp按鈕權(quán)限控制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS+html5 canvas實(shí)現(xiàn)的簡單繪制折線圖效果示例
這篇文章主要介紹了JS+html5 canvas實(shí)現(xiàn)的簡單繪制折線圖效果,結(jié)合實(shí)例形式分析了js結(jié)合HTML5 canvas技術(shù)實(shí)現(xiàn)圖形繪制的數(shù)值運(yùn)算與數(shù)組遍歷等操作技巧,需要的朋友可以參考下2017-03-03
JavaScript調(diào)用后臺(tái)的三種方法實(shí)例
這篇文章介紹了JavaScript調(diào)用后臺(tái)的三種方法實(shí)例,有需要的朋友可以參考一下2013-10-10
淺析Javascript的自動(dòng)分號(hào)插入(ASI)機(jī)制
我們大家都知道在寫java和c時(shí),必須要在語句后加分號(hào),否則編譯通不過。而js不同,存在自動(dòng)分好插入機(jī)制,下文簡稱ASI。它會(huì)給源代碼的 token 流自動(dòng)插入分號(hào)。下面這篇文章我們就來談?wù)凧avascript的自動(dòng)分號(hào)插入(ASI)機(jī)制。2016-09-09

