UNPKG

gnip-vue3-lazy-load

Version:

用于vue3图片懒加载使用,通过指令实现

2 lines (1 loc) 13 kB
(function(o,n){typeof exports=="object"&&typeof module<"u"?module.exports=n():typeof define=="function"&&define.amd?define(n):(o=typeof globalThis<"u"?globalThis:o||self,o["d-vue3-lazy-load"]=n())})(this,function(){"use strict";const o="",n=(e,t)=>{let A,l,i,s;if(e.scroll)A=t.clientHeight,l=t.clientWidth,s=e.el.offsetTop-t.scrollTop,i=e.el.offsetLeft-t.scrollLeft;else{const{top:I,left:E}=e.el.getBoundingClientRect();s=I,i=E,A=document.documentElement.clientHeight,l=document.documentElement.clientWidth}return s<A&&i<l},c=e=>{e.src=o},r=(e,t)=>{let A=null;return function(...l){A&&clearTimeout(A),A=setTimeout(()=>{e.apply(this,...l)},t)}};class g{constructor({errorImg:t,src:A,el:l,transitionTime:i}){this.el=l,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 a="";class w{constructor(t){this.imgPoolList=new Map,this.noScrollParentimgPoolList=[],this.scrollParentimgPoolList=[],this.pooListField="noScrollParentimgPoolList",this.isBindScrollWindow=!1,this.isBindScrollScrollParent=!1,this.errorImg=t.errorImg||a,this.loadingImg=t.loadingImg||o,this.scrollParent=null,this.isScrollParent=!1,this.transitionTime=t.transitionTime||.9,this.debounceTime=t.debounceTime||200,this.debounceHandleScroll=r(this.handleScroll,this.debounceTime).bind(this)}mounted(t,A,l){console.log(t),this.isScrollParent=A.modifiers.scroll,this.pooListField=this.isScrollParent?"scrollParentimgPoolList":"noScrollParentimgPoolList",this.imgPoolList.set(t,new g({src:A.value,errorImg:this.errorImg,el:t,transitionTime:this.transitionTime,scroll:this.isScrollParent})),c(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[l,i]of this.imgPoolList)t==l&&!i.loaded&&(i.src=A.value);this.handleScroll()}handleScroll(){for(let[t,A]of this.imgPoolList)this.scrollParent?n(A,this.scrollParent)&&!A.loaded&&this.resolveImgInstance(A):n(A)&&!A.loaded&&this.resolveImgInstance(A)}resolveImgInstance(t){t.loadImg().then(()=>{for(let[A,l]of this.imgPoolList)t.el==A&&(l.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}}return{install(e,t={}){const A=new w(t);console.log(e),e.directive("lazy",{mounted:A.mounted.bind(A)})}}});