import Vue from 'vue' import router from '@/router' import store from '@/store' /** * 获取UUID * 生成一个标准的UUID(例如:xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx) * 使用随机数和指定格式的规则生成UUID */ export function getUUID() { return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => { return (c === 'x' ? (Math.random() * 16 | 0) : ('r&0x3' | '0x8')).toString(16) }) } /** * 检查是否有某个权限 * @param {*} key 权限的标识符 * @returns {boolean} 如果权限列表中包含该权限返回true,否则返回false */ export function isAuth(key) { // 从 sessionStorage 中获取权限列表,并转换为数组,如果没有权限列表,默认返回空数组 return JSON.parse(sessionStorage.getItem('permissions') || '[]').indexOf(key) !== -1 || false } /** * 将平面数据转换为树形数据 * @param {*} data 原始平面数据 * @param {*} id 唯一标识符字段,默认为'id' * @param {*} pid 父级标识符字段,默认为'parentId' * @returns {Array} 转换后的树形数据 */ export function treeDataTranslate(data, id = 'id', pid = 'parentId') { var res = [] // 存储最终的树形结构 var temp = {} // 临时存储每个节点,以便快速查找父节点 // 将数据转换为临时对象,key为节点的id,值为节点本身 for (var i = 0; i < data.length; i++) { temp[data[i][id]] = data[i] } // 遍历数据,根据pid将节点组织成树形结构 for (var k = 0; k < data.length; k++) { // 如果节点的父节点存在,并且当前节点的id不等于父节点的id if (temp[data[k][pid]] && data[k][id] !== data[k][pid]) { // 如果父节点没有'children'属性,则初始化为数组 if (!temp[data[k][pid]]['children']) { temp[data[k][pid]]['children'] = [] } // 如果父节点没有'_level'属性,则设置为1 if (!temp[data[k][pid]]['_level']) { temp[data[k][pid]]['_level'] = 1 } // 当前节点的级别为父节点的级别+1 data[k]['_level'] = temp[data[k][pid]]._level + 1 // 将当前节点推送到父节点的children数组中 temp[data[k][pid]]['children'].push(data[k]) } else { // 如果当前节点是根节点,直接推送到结果数组中 res.push(data[k]) } } return res // 返回转换后的树形数据 } /** * 清除登录信息 * 用于用户退出时,清理本地存储的登录信息 */ export function clearLoginInfo() { // 删除cookie中的'token' Vue.cookie.delete('token') // 目前注释掉了重置store的操作,若需要可以解除注释 // store.commit('resetStore') // 重置动态菜单路由标志 router.options.isAddDynamicMenuRoutes = false }