gnip-vue3-lazy-load
Version:
用于vue3图片懒加载使用,通过指令实现
101 lines (100 loc) • 13.6 kB
JavaScript
const n = "", s = (l, t) => {
let A, e, i, o;
if (l.scroll)
A = t.clientHeight, e = t.clientWidth, o = l.el.offsetTop - t.scrollTop, i = l.el.offsetLeft - t.scrollLeft;
else {
const { top: c, left: r } = l.el.getBoundingClientRect();
o = c, i = r, A = document.documentElement.clientHeight, e = document.documentElement.clientWidth;
}
return o < A && i < e;
}, g = (l) => {
l.src = n;
}, a = (l, t) => {
let A = null;
return function(...e) {
A && clearTimeout(A), A = setTimeout(() => {
l.apply(this, ...e);
}, t);
};
};
class w {
constructor({ errorImg: t, src: A, el: e, transitionTime: i }) {
this.el = e, this.errorImg = t, this.src = A, this.loaded = !1, this.transitionTime = i, this.loadingError = !1;
}
loadImg() {
return new Promise((t, A) => {
this.el.style.opacity = "0", this.addTransition(), this.el.src = this.src, this.el.onload = () => {
t();
}, this.el.onerror = () => {
this.el.src = this.errorImg, t();
}, this.loaded = !0;
});
}
addTransition() {
requestAnimationFrame(() => {
this.el.style.transition = `opacity ${1.2}s ease-in-out`, this.el.style.opacity = "1";
});
}
}
const I = "";
class E {
constructor(t) {
this.imgPoolList = /* @__PURE__ */ new Map(), this.noScrollParentimgPoolList = [], this.scrollParentimgPoolList = [], this.pooListField = "noScrollParentimgPoolList", this.isBindScrollWindow = !1, this.isBindScrollScrollParent = !1, this.errorImg = t.errorImg || I, this.loadingImg = t.loadingImg || n, this.scrollParent = null, this.isScrollParent = !1, this.transitionTime = t.transitionTime || 0.9, this.debounceTime = t.debounceTime || 200, this.debounceHandleScroll = a(this.handleScroll, this.debounceTime).bind(this);
}
mounted(t, A, e) {
console.log(t), this.isScrollParent = A.modifiers.scroll, this.pooListField = this.isScrollParent ? "scrollParentimgPoolList" : "noScrollParentimgPoolList", this.imgPoolList.set(
t,
new w({
src: A.value,
errorImg: this.errorImg,
el: t,
transitionTime: this.transitionTime,
scroll: this.isScrollParent
})
), g(t), this.handleScroll(), this.findScrollParent(t) ? (!this.isBindScrollScrollParent && this.scrollParent.addEventListener("scroll", this.debounceHandleScroll), this.isBindScrollScrollParent = !0) : (!this.isBindScrollWindow && window.addEventListener("scroll", this.debounceHandleScroll), this.isBindScrollWindow = !0);
}
unmounted() {
this.scrollParentimgPoolList = [], this.noScrollParentimgPoolList = [];
}
update(t, A) {
this.updateImageInstance(t, A);
}
updateImageInstance(t, A) {
for (let [e, i] of this.imgPoolList)
t == e && !i.loaded && (i.src = A.value);
this.handleScroll();
}
handleScroll() {
for (let [t, A] of this.imgPoolList)
this.scrollParent ? s(A, this.scrollParent) && !A.loaded && this.resolveImgInstance(A) : s(A) && !A.loaded && this.resolveImgInstance(A);
}
resolveImgInstance(t) {
t.loadImg().then(() => {
for (let [A, e] of this.imgPoolList)
t.el == A && (e.loaded = !0);
}).catch(() => {
});
}
findScrollParent(t) {
if (!this.isScrollParent)
return !1;
let A = t.parentNode;
for (; A; ) {
if (getComputedStyle(A).getPropertyValue("overflow") == "scroll" || getComputedStyle(A).getPropertyValue("overflow") == "auto" || getComputedStyle(A).getPropertyValue("overflow-x") == "scroll" || getComputedStyle(A).getPropertyValue("overflow-x") == "auto" || getComputedStyle(A).getPropertyValue("overflow-y") == "scroll" || getComputedStyle(A).getPropertyValue("overflow-y") == "auto")
return this.scrollParent = A, !0;
A = A.parentNode;
}
return !1;
}
}
const m = {
install(l, t = {}) {
const A = new E(t);
console.log(l), l.directive("lazy", {
mounted: A.mounted.bind(A)
});
}
};
export {
m as default
};