码迷,mamicode.com
首页 > 编程语言 > 详细

原生javascript代码懒加载

时间:2017-06-09 11:10:16      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:name   透明   alpha   设置   return   加载   att   elements   dev   

1.先定义需要懒加载的样式;

class="lazyload"

2.设置初始透明度为0.1;

.lazyload{

  filter: Alpha(opacity=10); -moz-opacity:0.1; opacity:0.1;

}

3.把真正需要加载的真实地址放在data-src属性中;

src="懒加载图片.png" data-src="真实图片";

4.

前端开发周大伟同学JavaScript代码编写:

function lazyload(){  

  var lazyload=document.getElementsByClassName("lazyload");

  window.addEventlistener("scroll",function(){

    setTimeout(function(){

      for(var i=0;i<lazyload.length;i++){

        var _this=lazyload[i];

        var clientHeight=document.documentElement.clientHeight || document.body.clientHeight;

        var scrollTop=document.documentElement.scrollTop || document.body.scrollTop;

        if(clientHeight+scrollTop>=offsetTop(_this)){

          _this.setAttribute("src",_this.getAttribute("data-src"));

          _this.style.opacity="1";

        }

      }

    },100);

  });

}

//获取offsetTop和offsetLeft值的js代码(兼容)

function offsetTop( elements ){ 
  var top = elements.offsetTop; 
  var parent = elements.offsetParent; 
  while( parent != null ){ 
    top += parent.offsetTop; 
    parent = parent.offsetParent; 
  }; 
  return top; 
}; 


function offsetLeft( elements ){ 
  var left = elements.offsetLeft; 
  var parent = elements.offsetParent; 
  while( parent != null ){ 
    left += parent.offsetLeft; 
    parent = parent.offsetParent; 
  }; 
  return parent; 
}; 

 

原生javascript代码懒加载

标签:name   透明   alpha   设置   return   加载   att   elements   dev   

原文地址:http://www.cnblogs.com/zhoudawei/p/6970725.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!