// import dayjs from 'dayjs' //替换dayjs 兼容性会好一点,但是速度就很慢了,之前测了一下,大概快30倍?有点忘记了 //缓存 解析值,加速一点点吧 const cacheParseTime = function () { let cacheString = {} let cacheValue = {} return function(timeName, timeString) { if (cacheString[timeName] !== timeString) { cacheString[timeName] = timeString; cacheValue[timeName] = parseTime(timeString) } return cacheValue[timeName] } }() // pStart 关于缓存这个值是因为getWidthAbout2Times和getPositonOffset通常是前后连续调用,start 值会再两个函数中分别用到一次 /** * 根据配置项计算两个时间的在gantt 图中的长度 * 注:时间上start 早, end 晚 * * @export * @param {string} start * @param {string} end * @param {{scale:number,cellWidth:number}} arg * @returns number */ export function getWidthAbout2Times(start, end, arg) { let { scale, cellWidth } = arg; let pStart = cacheParseTime('pStart', start); let pEnd = parseTime(end) return diffTimeByMinutes(pStart, pEnd) / scale * cellWidth; } /** * 根据配置项计算 相对于 时间轴起始时间的距离 是 getWidthAbout2Times 的特化 * 注:时间上,time 晚 beginTimeOfTimeLine 早 * * @export * @param {string} time * @param {string} beginTimeOfTimeLine * @param {{scale:number,cellWidth:number}} arg * @returns number */ export function getPositonOffset(time, beginTimeOfTimeLine, arg) { let { scale, cellWidth, } = arg; let pTime = cacheParseTime('pStart', time); let pBeginTimeOfTimeLine = cacheParseTime('pBeginTimeOfTimeLine', beginTimeOfTimeLine); return diffTimeByMinutes(pBeginTimeOfTimeLine, pTime) / scale * cellWidth; } function parseTime(time) { return new Date(time) } /** * 计算两个时间相差的分钟数 * * @param {string} start * @param {string} end * @returns */ function diffTimeByMinutes(start, end) { let diff = end.getTime() - start.getTime() return (diff / 1000 / 60) } // function parseTime(time){ // return dayjs(time) // } // function diffTimeByMinutes(start,end){ // return end.diff(start, "m", true) // }