UNPKG

microvideo-component

Version:

microvideo components

50 lines (47 loc) 1.53 kB
/** * 防抖函数 * @param {Function} func 需要执行的函数 * @param {Number} wait 延迟执行时间(毫秒) * @param {Boolean} immediate true 立即执行,false 非立即执行 * @returns */ export function debounce(func, wait, immediate) { let timeout, args, context, timestamp, result const later = function() { // 据上一次触发时间间隔 const last = +new Date() - timestamp // 上次被包装函数被调用时间间隔 last 小于设定时间间隔 wait if (last < wait && last > 0) { timeout = setTimeout(later, wait - last) } else { timeout = null // 如果设定为immediate===true,因为开始边界已经调用过了此处无需调用 if (!immediate) { result = func.apply(context, args) if (!timeout) context = args = null } } } return function(...args) { context = this timestamp = +new Date() const callNow = immediate && !timeout // 如果延时不存在,重新设定延时 if (!timeout) timeout = setTimeout(later, wait) if (callNow) { result = func.apply(context, args) context = args = null } return result } } /** * 获取dom元素对象的style 数值 * @param {Dom} el dom原始 * @param {String} key 获取的属性 * @returns number */ export function getDomStyleNumber(el, key) { const styleObj = getComputedStyle(el) return Number(styleObj[key].replace(/\s+|px/gi,"")) }