93 lines
2.7 KiB
JavaScript
93 lines
2.7 KiB
JavaScript
import Vue from 'vue'
|
|
import router from '@/router'
|
|
import store from '@/store'
|
|
|
|
/**
|
|
* 获取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
|
|
*/
|
|
export function isAuth (key) {
|
|
// return JSON.parse(sessionStorage.getItem('permissions') || '[]').indexOf(key) !== -1 || false
|
|
return true
|
|
}
|
|
|
|
/**
|
|
* 树形数据转换
|
|
* @param {*} data
|
|
* @param {*} id
|
|
* @param {*} pid
|
|
*/
|
|
export function treeDataTranslate (data, id = 'id', pid = 'parentId') {
|
|
var res = []
|
|
var temp = {}
|
|
for (var i = 0; i < data.length; i++) {
|
|
temp[data[i][id]] = data[i]
|
|
}
|
|
for (var k = 0; k < data.length; k++) {
|
|
if (temp[data[k][pid]] && data[k][id] !== data[k][pid]) {
|
|
if (!temp[data[k][pid]]['children']) {
|
|
temp[data[k][pid]]['children'] = []
|
|
}
|
|
if (!temp[data[k][pid]]['_level']) {
|
|
temp[data[k][pid]]['_level'] = 1
|
|
}
|
|
data[k]['_level'] = temp[data[k][pid]]._level + 1
|
|
temp[data[k][pid]]['children'].push(data[k])
|
|
} else {
|
|
res.push(data[k])
|
|
}
|
|
}
|
|
return res
|
|
}
|
|
|
|
/**
|
|
* 清除登录信息
|
|
*/
|
|
export function clearLoginInfo () {
|
|
Vue.cookie.delete('token')
|
|
store.commit('resetStore')
|
|
router.options.isAddDynamicMenuRoutes = false
|
|
}
|
|
|
|
|
|
export function debounce(func, wait, immediate) {
|
|
let timeout; // 定义一个计时器变量,用于延迟执行函数
|
|
return function (...args) { // 返回一个包装后的函数
|
|
const context = this; // 保存函数执行上下文对象
|
|
const later = function () { // 定义延迟执行的函数
|
|
timeout = null; // 清空计时器变量
|
|
if (!immediate) func.apply(context, args); // 若非立即执行,则调用待防抖函数
|
|
};
|
|
const callNow = immediate && !timeout; // 是否立即调用函数的条件
|
|
clearTimeout(timeout); // 清空计时器
|
|
timeout = setTimeout(later, wait); // 创建新的计时器,延迟执行函数
|
|
if (callNow) func.apply(context, args); // 如果满足立即调用条件,则立即执行函数
|
|
};
|
|
}
|
|
|
|
// 节流函数
|
|
export function throttle(func, wait) {
|
|
let timeout; // 定义一个计时器变量,用于限制函数调用频率
|
|
return function (...args) { // 返回一个包装后的函数
|
|
const context = this; // 保存函数执行上下文对象
|
|
if (!timeout) { // 如果计时器不存在
|
|
func.apply(context, args); // 执行函数
|
|
timeout = setTimeout(() => {
|
|
timeout = null; // 清空计时器变量
|
|
}, wait); // 创建计时器,在指定时间后重置计时器变量
|
|
}
|
|
};
|
|
}
|
|
|
|
|
|
|