| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241 |
- // +---------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +---------------------------------------------------------------------
- // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
- // +---------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +---------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +---------------------------------------------------------------------
- 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;
- };
- /**
- * @returns {String} 当前浏览器名称
- */
- export const getExplorer = () => {
- const ua = window.navigator.userAgent;
- const isExplorer = (exp) => {
- return ua.indexOf(exp) > -1;
- };
- if (isExplorer('MSIE')) return 'IE';
- else if (isExplorer('Firefox')) return 'Firefox';
- else if (isExplorer('Chrome')) return 'Chrome';
- else if (isExplorer('Opera')) return 'Opera';
- else if (isExplorer('Safari')) return 'Safari';
- };
- /**
- * @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]);
- };
- /**
- * 去除乘法计算出现多位小数
- * @param arg1返回值,arg2乘以的参数
- */
- export const accMul = (arg1, arg2) => {
- var m = 0,
- s1 = arg1.toString(),
- s2 = arg2.toString();
- try {
- m += s1.split('.')[1].length;
- } catch (e) {}
- try {
- m += s2.split('.')[1].length;
- } catch (e) {}
- return (Number(s1.replace('.', '')) * Number(s2.replace('.', ''))) / Math.pow(10, m);
- };
|