export const revisePath = (path) => {
if (!path) {
return "";
}
if (path[0] == "/") {
return path;
} else {
return `/${path}`;
}
};
export function getUrlParam(name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if (r != null) return decodeURIComponent(r[2]);
return null;
}
export function firstMenu(list) {
let path = "";
const fn = (arr) => {
arr.forEach((e) => {
if (e.type == 1) {
if (!path) {
path = e.path;
}
} else {
fn(e.children);
}
});
};
fn(list);
return path || "/404";
}
export function orderBy(list, key) {
return list.sort((a, b) => a[key] - b[key]);
}
export function deepTree(list) {
let newList = [];
let map = {};
list.forEach((e) => (map[e.id] = e));
list.forEach((e) => {
let parent = map[e.parentId];
if (parent) {
(parent.children || (parent.children = [])).push(e);
} else {
if (!e.parentId) {
newList.push(e);
}
}
});
const fn = (list) => {
list.map((e) => {
if (e.children instanceof Array) {
e.children = orderBy(e.children, "orderNum");
fn(e.children);
}
});
};
fn(newList);
return orderBy(newList, "orderNum");
}
export function revDeepTree(list = []) {
let d = [];
const deep = (list) => {
list.forEach((e) => {
d.push(e);
if (e.children && isArray(e.children)) {
deep(e.children);
}
});
};
deep(list || []);
return d;
}
export function debounce(fn, delay) {
let timer = null;
return function () {
let args = arguments;
let context = this;
if (timer) {
clearTimeout(timer);
timer = setTimeout(function () {
fn.apply(context, args);
}, delay);
} else {
timer = setTimeout(function () {
fn.apply(context, args);
}, delay);
}
};
}
export function isArray(value) {
if (typeof Array.isArray === "function") {
return Array.isArray(value);
} else {
return Object.prototype.toString.call(value) === "[object Array]";
}
}
export function isObject(value) {
return Object.prototype.toString.call(value) === "[object Object]";
}
export function isNumber(value) {
return !isNaN(Number(value));
}
export function isFunction(value) {
return typeof value == "function";
}
export function isString(value) {
return typeof value == "string";
}
export function isEmpty(value) {
if (isArray(value)) {
return value.length === 0;
}
if (isObject(value)) {
return Object.keys(value).length === 0;
}
return value === "" || value === undefined || value === null;
}
export function cloneDeep(obj) {
let d = isArray(obj) ? obj : {};
if (isObject(obj)) {
for (let key in obj) {
if (obj.hasOwnProperty && obj.hasOwnProperty(key)) {
if (obj[key] && typeof obj[key] === "object") {
d[key] = cloneDeep(obj[key]);
} else {
d[key] = obj[key];
}
}
}
}
return d;
}
export function clone(obj) {
return Object.create(Object.getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj));
}
export function certainProperty(obj, keys) {
return keys.reduce((result, key) => {
if (obj.hasOwnProperty(key)) {
result[key] = obj[key];
}
return result;
}, {});
}
export function deepMerge(a, b) {
let k;
for (k in b) {
a[k] =
a[k] && a[k].toString() === "[object Object]" ? deepMerge(a[k], b[k]) : (a[k] = b[k]);
}
return a;
}
export function contains(parent, node) {
if (document.documentElement.contains) {
return parent !== node && parent.contains(node);
} else {
while (node && (node = node.parentNode)) if (node === parent) return true;
return false;
}
}
export function moreList(res, { list, pagination }) {
const { page, size } = res.pagination;
const len = res.list.length;
const max = list.length;
if (page == 1) {
list.splice(0, max, ...res.list);
} else {
let start = max - (max % size);
let end = start + len;
list.splice(start, end, ...res.list);
}
if (len == size) {
res.pagination.page += 1;
}
Object.assign(pagination, res.pagination);
return page != 1;
}
export function isPc() {
const userAgentInfo = navigator.userAgent;
const Agents = ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod"];
let flag = true;
for (let v = 0; v < Agents.length; v++) {
if (userAgentInfo.indexOf(Agents[v]) > 0) {
flag = false;
break;
}
}
return flag;
}
export const isIOS = !!navigator.userAgent.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
export function getBrowser() {
let ua = navigator.userAgent.toLowerCase();
let btypeInfo = (ua.match(/firefox|chrome|safari|opera/g) || "other")[0];
if ((ua.match(/msie|trident/g) || [])[0]) {
btypeInfo = "msie";
}
let pc = "";
let prefix = "";
let plat = "";
let isTocuh =
"ontouchstart" in window || ua.indexOf("touch") !== -1 || ua.indexOf("mobile") !== -1;
if (isTocuh) {
if (ua.indexOf("ipad") !== -1) {
pc = "pad";
} else if (ua.indexOf("mobile") !== -1) {
pc = "mobile";
} else if (ua.indexOf("android") !== -1) {
pc = "androidPad";
} else {
pc = "pc";
}
} else {
pc = "pc";
}
switch (btypeInfo) {
case "chrome":
case "safari":
case "mobile":
prefix = "webkit";
break;
case "msie":
prefix = "ms";
break;
case "firefox":
prefix = "Moz";
break;
case "opera":
prefix = "O";
break;
default:
prefix = "webkit";
break;
}
plat = ua.indexOf("android") > 0 ? "android" : navigator.platform.toLowerCase();
return {
version: (ua.match(/[\s\S]+(?:rv|it|ra|ie)[\/: ]([\d.]+)/) || [])[1],
plat: plat,
type: btypeInfo,
pc: pc,
prefix: prefix,
isMobile: pc == "pc" ? false : true
};
}
没有合适的资源?快使用搜索试试~ 我知道了~
COOL-ADMIN 基于uniCloud后台通用管理系统
共266个文件
svg:112个
js:69个
vue:50个
需积分: 5 1 下载量 33 浏览量
2023-03-22
00:42:11
上传
评论 1
收藏 263KB ZIP 举报
温馨提示
0.0.9(2021-03-17) 适配手机端; 调整前端目录结构; 0.0.8(2020-09-02) 精简优化云函数依赖包 更新通用crud到最新版 修复分页显示问题 0.0.6(2020-09-02) 精简优化云函数依赖包 更新通用crud到最新版 修复分页显示问题 0.0.5(2020-08-08) 新增视频上传 新增优化图片空间 优化上传逻辑 0.0.4(2020-08-07) 优化cl-upload组件 修复sys_data索引过长导致的报错 0.0.2(2020-08-06) 修改文案 v0.0.1(2020-08-06) 新增用户、角色、菜单、部门管理 新增多种组件如:图片空间、邀请码、右键菜单等 新增登录和权限校验 新增通用的云函数框架 新增权限控制 同步COOL-ADMIN-PRO新特性
资源推荐
资源详情
资源评论
收起资源包目录
COOL-ADMIN 基于uniCloud后台通用管理系统 (266个子文件)
crud.code-snippets 1KB
func.code-snippets 801B
.DS_Store 8KB
.gitignore 227B
index.js 5KB
index.js 3KB
menu.js 3KB
user.js 2KB
index.js 2KB
index.js 2KB
test-service.js 2KB
login.js 2KB
service.js 2KB
crud.js 2KB
b-cl-context-menu.js 2KB
index.js 2KB
department.js 2KB
menu.js 2KB
authority.js 1KB
index.js 1KB
index.js 1KB
role.js 1KB
perms.js 1KB
user.js 1KB
index.js 1KB
data.js 1KB
user.js 1KB
index.js 1KB
main.js 1KB
index.js 1KB
role.js 1KB
request.js 952B
index.js 923B
process.js 908B
comm.js 820B
service.js 817B
index.js 809B
verify.js 789B
vue.config.js 737B
login.js 709B
clipboard.js 632B
log.js 622B
getters.js 602B
task.js 562B
index.js 536B
index.js 503B
cloud.js 501B
index.js 485B
log.js 483B
log.js 462B
department.js 409B
env.js 394B
app.js 378B
menu.js 362B
conf.js 316B
config.js 296B
index.js 294B
info.js 287B
store.js 285B
require.js 269B
index.js 262B
dept.js 247B
user.js 238B
type.js 234B
index.js 213B
info.js 212B
param.js 178B
type.js 119B
info.js 119B
param.js 114B
menu.js 113B
role.js 113B
index.js 109B
db_init.json 21KB
package-lock.json 9KB
manifest.json 3KB
pages.json 977B
launch.json 457B
package.json 413B
package.json 367B
package.json 316B
package.json 305B
package.json 265B
package.json 218B
yarn.lock 18KB
login.png 4KB
custom-avatar.png 4KB
custom-avatar.png 4KB
logo.png 4KB
default-avatar.png 4KB
default-avatar.png 4KB
silder.png 3KB
silder-simple.png 1KB
.prettierrc 150B
uni.scss 2KB
theme.scss 2KB
iconfont.scss 2KB
index.scss 1KB
index.scss 1018B
index.scss 654B
共 266 条
- 1
- 2
- 3
资源评论
$encoding
- 粉丝: 98
- 资源: 14
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- STM32开发 IIR带阻滤波器 STM32实现IIR无限冲击响应带阻滤波器设计,巴特沃斯滤波器,代码工整,自编代码,注释详细,赠送巴特沃斯和切比雪夫IIR带阻滤波器MATLAB程序
- 四轴抓取视觉旋转标定源代码,学习机器视觉和运动控制的最佳例子,基于VS2015 C++ 实现,仿雅马哈四轴机械手抓取程序,实现把两个任意摆放的物料通过视觉算法和运动控制指令定位摆放到指定的位置并拼接起
- COOFDM的Matlab仿真程序,包括文档代码解释和理论解释
- 伺服驱动器,你还在为伺服驱动器 FPGA架构苦恼吗,本方案FPGA代码实现电流环 速度环 位置环 SVPWM 坐标变 测速 分频 滤波器等,程序方便移植不同的平台,具有很高的研究价值
- omron欧姆龙CJ CP程序 欧姆龙CJ2M-CPU35,主机架搭载两套从机架,ID263.OD263等输入输出IO模块 全自动电池注液封装机,NC413四轴模块轴控制,SCU31无协议读写欧姆龙E
- 基于PI控制器的单相逆变器闭环控制模型,采用电压电流双环控制 波形输出良好,输出跟随给定220V交流输出 运行环境为matlab simulink plecs等
- PLC案例 污水处理系统 - 污水处理项目 某大厂技术给某国企做的污水处理项目,程序规范,图纸清晰,具有很好的参考价值 PLC: 西门子s7 200smart 系统涉及好氧发酵、厌氧发酵、冷热水P
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功