'admin-22.12.12:发布v2.4.21版本,具体更新内容查看CHANGELOG.md' !42 修复 工作流无法添加新节点问题 Merge pull request !42 from beta/bugfix_workflow 修复 工作流无法添加新节点问题 1. 修复 工作流无法添加新节点问题 2. 修复 左侧导航无法隐藏问题 'admin-22.12.09:发布v2.4.2版本,具体更新内容查看CHANGELOG.md' !41 修复get请求传递嵌套对象或数组时无法正常编码问题 Merge pull request !41 from 随心/master !40 开启TagsView缓存后,刷新后所有的路由都变成组件缓存了 Merge pull request !40 from mrjimin/master 修复get请求传递嵌套对象或数组时无法正常编码问题 update src/layout/routerView/parent.vue. Signed-off-by: mrjimin <z8888788@163.com> update src/layout/routerView/parent.vue. 这里应该拿到的是已经设置开启组件缓存的路由,而不是全部,需要先判断item.meta.isKeepAlive Signed-off-by: mrjimin <z8888788@163.com> 'admin-22.11.30:发布v2.4.1版本,具体更新内容查看CHANGELOG.md' Merge branch 'master' of https://gitee.com/lyt-top/vue-next-admin 'admin-22.11.30:删除v2.4.0版本不需要的依赖' update src/views/error/404.vue. Signed-off-by: lyt-Top <1105290566@qq.com> update src/components/table/index.vue. Signed-off-by: lyt-Top <1105290566@qq.com> 'admin-22.11.30:修改v2.4.0文字说明' 'admin-22.11.30:修改v2.4.0文字说明' 'admin-22.11.29:发布v2.4.0版本,具体更新内容查看CHANGELOG.md' 'admin-22.11.19:修复v2.3.0版本动态路由事件调用关闭当前tagsview、普通路由刷新界面参数丢失问题' 'admin-22.11.18:优化v2.3.0版本tagsview风格5兼容火狐' 'admin-22.11.17:优化v2.3.0版本iframe右键菜单刷新问题' ...
66 lines
1.8 KiB
TypeScript
66 lines
1.8 KiB
TypeScript
/**
|
||
* 判断两数组字符串是否相同(用于按钮权限验证),数组字符串中存在相同时会自动去重(按钮权限标识不会重复)
|
||
* @param news 新数据
|
||
* @param old 源数据
|
||
* @returns 两数组相同返回 `true`,反之则反
|
||
*/
|
||
export function judementSameArr(newArr: unknown[] | string[], oldArr: string[]): boolean {
|
||
const news = removeDuplicate(newArr);
|
||
const olds = removeDuplicate(oldArr);
|
||
let count = 0;
|
||
const leng = news.length;
|
||
for (let i in olds) {
|
||
for (let j in news) {
|
||
if (olds[i] === news[j]) count++;
|
||
}
|
||
}
|
||
return count === leng ? true : false;
|
||
}
|
||
|
||
/**
|
||
* 判断两个对象是否相同
|
||
* @param a 要比较的对象一
|
||
* @param b 要比较的对象二
|
||
* @returns 相同返回 true,反之则反
|
||
*/
|
||
export function isObjectValueEqual<T>(a: T, b: T): boolean {
|
||
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;
|
||
}
|
||
|
||
/**
|
||
* 数组、数组对象去重
|
||
* @param arr 数组内容
|
||
* @param attr 需要去重的键值(数组对象)
|
||
* @returns
|
||
*/
|
||
export function removeDuplicate(arr: EmptyArrayType, attr?: string) {
|
||
if (!Object.keys(arr).length) {
|
||
return arr;
|
||
} else {
|
||
if (attr) {
|
||
const obj: EmptyObjectType = {};
|
||
return arr.reduce((cur: EmptyArrayType[], item: EmptyArrayType) => {
|
||
obj[item[attr]] ? '' : (obj[item[attr]] = true && item[attr] && cur.push(item));
|
||
return cur;
|
||
}, []);
|
||
} else {
|
||
return [...new Set(arr)];
|
||
}
|
||
}
|
||
}
|