Vue 自定义图片/src懒加载

  if(!Array.prototype.remove){
        Array.prototype.remove = function(item){
            if(!this.length) return
            var index = this.indexOf(item);
            if( index > -1){
                this.splice(index,1);
                return this
            }
        }
    }
    var init = {
        lazyLoad: false,
        default: 'image/billnull.png'
    }

    var listenList = [];
    var imageCatcheList = [];

    const isAlredyLoad = (imageSrc) => {
        if(imageCatcheList.indexOf(imageSrc) > -1){
            return true;
        }else{
            return false;
        }
    }
    //检测图片是否可以加载,如果可以则进行加载
    const isCanShow = (item) =>{
        if(typeof item =='undefined')return false;
        var ele = item.ele;
        var src = item.src;
        //图片距离页面顶部的距离
        var top = ele.getBoundingClientRect().top;
        //页面可视区域的高度
        var windowHeight = window.innerHeight;
        //top  进入可视高度+可视高度一半的都展示
        var halfHeight=windowHeight*0.5
        if(top>1-windowHeight&&top  < (windowHeight+halfHeight)&&imageCatcheList.indexOf(src)==-1){
            ele.src = src;
            imageCatcheList.push(src);
            listenList.remove(item);
            console.log("加载了:"+src);
            return true;
        }else{
            return false;
        }
    };


    var preViousOffset=0;
    const isStopScroll=()=>{
       var currentOffset= window.scrollY;
        var length = listenList.length;
        if(preViousOffset==currentOffset&&length>0){
           for(let i = 0;i<length;i++ ){
               isCanShow(listenList[i]);
           }
        }
        preViousOffset=currentOffset;
    };
    //设置一个定时器不停的访问滚动条的距离 这个秒数决定了src赋值的时间  如果这个秒没有动就加载这个src
    setInterval(isStopScroll,1000);

    //滚动条监听
    const onListenScroll = () =>{
        window.addEventListener('scroll',function(){
            preViousOffset= window.scrollY;
        })
    };
    //Vue 指令最终的方法
    const addListener = (ele,binding) =>{
        imageCatcheList=[];//更新的时候去除记录
        //绑定的图片地址
        var imageSrc = binding.value;
        //如果已经加载过,则无需重新加载,直接将src赋值
        if(isAlredyLoad(imageSrc)){
            // ele.src = imageSrc;
            return false;
        }
        var item = {
            ele:ele,
            src:imageSrc
        }
        //图片显示默认的图片
        ele.src = init.default;
        //再看看是否可以显示此图片
        if(isCanShow(item)){
            return
        }
        //否则将图片地址和元素均放入监听的lisenList里
        listenList.push(item);

        //然后开始监听页面scroll事件
        onListenScroll();
    }

    // //注册一个全局的指令 v-lazyloadbill
    Vue.directive('lazyloadbill',{
        inserted:addListener,//被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。
        update:addListener//所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。
    })
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值