2021-06-19 17:49:42 +08:00
|
|
|
|
/**
|
2022-05-19 19:08:29 +08:00
|
|
|
|
* 判断两数组字符串是否相同(用于按钮权限验证),数组字符串中存在相同时会自动去重(按钮权限标识不会重复)
|
2021-06-19 17:49:42 +08:00
|
|
|
|
* @param news 新数据
|
|
|
|
|
* @param old 源数据
|
|
|
|
|
* @returns 两数组相同返回 `true`,反之则反
|
|
|
|
|
*/
|
2022-05-19 19:08:29 +08:00
|
|
|
|
export function judementSameArr(newArr: unknown[] | string[], oldArr: string[]): boolean {
|
|
|
|
|
const news = removeDuplicate(newArr);
|
|
|
|
|
const olds = removeDuplicate(oldArr);
|
2021-03-15 12:44:58 +08:00
|
|
|
|
let count = 0;
|
2022-05-19 19:08:29 +08:00
|
|
|
|
const leng = olds.length;
|
|
|
|
|
for (let i in olds) {
|
2021-03-15 12:44:58 +08:00
|
|
|
|
for (let j in news) {
|
2022-05-19 19:08:29 +08:00
|
|
|
|
if (olds[i] === news[j]) count++;
|
2021-03-15 12:44:58 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return count === leng ? true : false;
|
|
|
|
|
}
|
2021-08-01 18:30:30 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 判断两个对象是否相同
|
|
|
|
|
* @param a 要比较的对象一
|
|
|
|
|
* @param b 要比较的对象二
|
|
|
|
|
* @returns 相同返回 true,反之则反
|
|
|
|
|
*/
|
|
|
|
|
export function isObjectValueEqual(a: { [key: string]: any }, b: { [key: string]: any }) {
|
|
|
|
|
if (!a || !b) return false;
|
|
|
|
|
let aProps = Object.getOwnPropertyNames(a);
|
|
|
|
|
let bProps = Object.getOwnPropertyNames(b);
|
|
|
|
|
if (aProps.length != bProps.length) return false;
|
|
|
|
|
for (let i = 0; i < aProps.length; i++) {
|
|
|
|
|
let propName = aProps[i];
|
|
|
|
|
let propA = a[propName];
|
|
|
|
|
let propB = b[propName];
|
|
|
|
|
if (!b.hasOwnProperty(propName)) return false;
|
|
|
|
|
if (propA instanceof Object) {
|
|
|
|
|
if (!isObjectValueEqual(propA, propB)) return false;
|
|
|
|
|
} else if (propA !== propB) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
2022-05-19 19:08:29 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 数组、数组对象去重
|
|
|
|
|
* @param arr 数组内容
|
|
|
|
|
* @param attr 需要去重的键值(数组对象)
|
|
|
|
|
* @returns
|
|
|
|
|
*/
|
|
|
|
|
export function removeDuplicate(arr: any, attr?: string) {
|
|
|
|
|
if (!arr && !arr.length) {
|
|
|
|
|
return arr;
|
|
|
|
|
} else {
|
|
|
|
|
if (attr) {
|
|
|
|
|
const obj: any = {};
|
|
|
|
|
const newArr = arr.reduce((cur: any, item: any) => {
|
|
|
|
|
obj[item[attr]] ? '' : (obj[item[attr]] = true && item[attr] && cur.push(item));
|
|
|
|
|
return cur;
|
|
|
|
|
}, []);
|
|
|
|
|
return newArr;
|
|
|
|
|
} else {
|
|
|
|
|
return Array.from(new Set([...arr]));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|