ivew-comps2
Version:
ivew-comps2 公有云平台基础组件库本项目基于
234 lines (219 loc) • 7.36 kB
JavaScript
// export const forEach = (arr, fn) => {
// if (!arr.length || !fn) return;
// let i = -1;
// let len = arr.length;
// while (++i < len) {
// let item = arr[i];
// fn(item, i, arr);
// }
// };
// /**
// * @param {Array} arr1
// * @param {Array} arr2
// * @description 得到两个数组的交集, 两个数组的元素为数值或字符串
// */
// export const getIntersection = (arr1, arr2) => {
// let len = Math.min(arr1.length, arr2.length);
// let i = -1;
// let res = [];
// while (++i < len) {
// const item = arr2[i];
// if (arr1.indexOf(item) > -1) res.push(item);
// }
// return res;
// };
// /**
// * @param {Array} arr1
// * @param {Array} arr2
// * @description 得到两个数组的并集, 两个数组的元素为数值或字符串
// */
// export const getUnion = (arr1, arr2) => {
// return Array.from(new Set([...arr1, ...arr2]));
// };
// /**
// * @param {Array} target 目标数组
// * @param {Array} arr 需要查询的数组
// * @description 判断要查询的数组是否至少有一个元素包含在目标数组中
// */
// export const hasOneOf = (targetarr, arr) => {
// return targetarr.some(_ => arr.indexOf(_) > -1);
// };
// /**
// * @param {String|Number} value 要验证的字符串或数值
// * @param {*} validList 用来验证的列表
// */
// export function oneOf(value, validList) {
// for (let i = 0; i < validList.length; i++) {
// if (value === validList[i]) {
// return true;
// }
// }
// return false;
// }
// /**
// * @param {Number} timeStamp 判断时间戳格式是否是毫秒
// * @returns {Boolean}
// */
// const isMillisecond = timeStamp => {
// const timeStr = String(timeStamp);
// return timeStr.length > 10;
// };
// /**
// * @param {Number} timeStamp 传入的时间戳
// * @param {Number} currentTime 当前时间时间戳
// * @returns {Boolean} 传入的时间戳是否早于当前时间戳
// */
// const isEarly = (timeStamp, currentTime) => {
// return timeStamp < currentTime;
// };
// /**
// * @param {Number} num 数值
// * @returns {String} 处理后的字符串
// * @description 如果传入的数值小于10,即位数只有1位,则在前面补充0
// */
// const getHandledValue = num => {
// return num < 10 ? "0" + num : num;
// };
// /**
// * @param {Number} timeStamp 传入的时间戳
// * @param {Number} startType 要返回的时间字符串的格式类型,传入'year'则返回年开头的完整时间
// */
// const getDate = (timeStamp, startType) => {
// const d = new Date(timeStamp * 1000);
// const year = d.getFullYear();
// const month = getHandledValue(d.getMonth() + 1);
// const date = getHandledValue(d.getDate());
// const hours = getHandledValue(d.getHours());
// const minutes = getHandledValue(d.getMinutes());
// const second = getHandledValue(d.getSeconds());
// let resStr = "";
// if (startType === "year")
// resStr =
// year +
// "-" +
// month +
// "-" +
// date +
// " " +
// hours +
// ":" +
// minutes +
// ":" +
// second;
// else resStr = month + "-" + date + " " + hours + ":" + minutes;
// return resStr;
// };
// /**
// * @param {String|Number} timeStamp 时间戳
// * @returns {String} 相对时间字符串
// */
// export const getRelativeTime = timeStamp => {
// // 判断当前传入的时间戳是秒格式还是毫秒
// const IS_MILLISECOND = isMillisecond(timeStamp);
// // 如果是毫秒格式则转为秒格式
// if (IS_MILLISECOND) Math.floor((timeStamp /= 1000));
// // 传入的时间戳可以是数值或字符串类型,这里统一转为数值类型
// timeStamp = Number(timeStamp);
// // 获取当前时间时间戳
// const currentTime = Math.floor(Date.parse(new Date()) / 1000);
// // 判断传入时间戳是否早于当前时间戳
// const IS_EARLY = isEarly(timeStamp, currentTime);
// // 获取两个时间戳差值
// let diff = currentTime - timeStamp;
// // 如果IS_EARLY为false则差值取反
// if (!IS_EARLY) diff = -diff;
// let resStr = "";
// const dirStr = IS_EARLY ? "前" : "后";
// // 少于等于59秒
// if (diff <= 59) resStr = diff + "秒" + dirStr;
// // 多于59秒,少于等于59分钟59秒
// else if (diff > 59 && diff <= 3599)
// resStr = Math.floor(diff / 60) + "分钟" + dirStr;
// // 多于59分钟59秒,少于等于23小时59分钟59秒
// else if (diff > 3599 && diff <= 86399)
// resStr = Math.floor(diff / 3600) + "小时" + dirStr;
// // 多于23小时59分钟59秒,少于等于29天59分钟59秒
// else if (diff > 86399 && diff <= 2623859)
// resStr = Math.floor(diff / 86400) + "天" + dirStr;
// // 多于29天59分钟59秒,少于364天23小时59分钟59秒,且传入的时间戳早于当前
// else if (diff > 2623859 && diff <= 31567859 && IS_EARLY)
// resStr = getDate(timeStamp);
// else resStr = getDate(timeStamp, "year");
// return resStr;
// };
/**
* @description 绑定事件 on(element, event, handler)
*/
export const on = (function() {
if (document.addEventListener) {
return function(element, event, handler) {
if (element && event && handler) {
element.addEventListener(event, handler, false);
}
};
} else {
return function(element, event, handler) {
if (element && event && handler) {
element.attachEvent("on" + event, handler);
}
};
}
})();
/**
* @description 解绑事件 off(element, event, handler)
*/
export const off = (function() {
if (document.removeEventListener) {
return function(element, event, handler) {
if (element && event) {
element.removeEventListener(event, handler, false);
}
};
} else {
return function(element, event, handler) {
if (element && event) {
element.detachEvent("on" + event, handler);
}
};
}
})();
// /**
// * 判断一个对象是否存在key,如果传入第二个参数key,则是判断这个obj对象是否存在key这个属性
// * 如果没有传入key这个参数,则判断obj对象是否有键值对
// */
// export const hasKey = (obj, key) => {
// if (key) return key in obj;
// else {
// let keysArr = Object.keys(obj);
// return keysArr.length;
// }
// };
// /**
// * @param {*} obj1 对象
// * @param {*} obj2 对象
// * @description 判断两个对象是否相等,这两个对象的值只能是数字或字符串
// */
// export const objEqual = (obj1, obj2) => {
// const keysArr1 = Object.keys(obj1);
// const keysArr2 = Object.keys(obj2);
// if (keysArr1.length !== keysArr2.length) return false;
// else if (keysArr1.length === 0 && keysArr2.length === 0) return true;
// /* eslint-disable-next-line */ else
// return !keysArr1.some(key => obj1[key] != obj2[key])
// };
export function typeOf(obj) {
const toString = Object.prototype.toString;
const map = {
"[object Boolean]": "boolean",
"[object Number]": "number",
"[object String]": "string",
"[object Function]": "function",
"[object Array]": "array",
"[object Date]": "date",
"[object RegExp]": "regExp",
"[object Undefined]": "undefined",
"[object Null]": "null",
"[object Object]": "object",
};
return map[toString.call(obj)];
}