炫意html5
最早CSS3和HTML5移动技术网站之一

img 的data-src 属性及懒加载

一、什么是图片懒加载

当访问一个页面的时候,先把img元素或是其他元素的背景图片路径替换成一张大小为1*1px图片的路径(这样就只需请求一次),当图片出现在浏览器的可视区域内时,才设置图片真正的路径,让图片显示出来。这就是图片懒加载。

俗一点:
1、就是创建一个自定义属性data-src存放真正需要显示的图片路径,而img自带的src放一张大小为1 * 1px的图片路径
2、当页面滚动直至此图片出现在可视区域时,用js取到该图片的data-src的值赋给src。
ps:自定义属性可以取任何名字

HTML

<div class="container">
  <img src="img/loading.png" alt="1" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="2" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="3" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="4" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="5" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="6" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="7" data-src="img/photo-3.jpeg">
  <img src="img/loading.png" alt="8" data-src="img/photo-3.jpeg">
</div>

CSS

<style>
 .container {
  max-width: 800px;
  margin: 0 auto;
}
.container:after{
  content: '';
  display: block;
  clear: both;
}
.container img {
  float: left;
  width: 50%;
}
h1{
  clear: both;
}
 </style>

二、懒加载需要了解的问题

1、如何加载图片?
2、如何判断一个元素出现在视野中?

如何加载图片?

只需要把data-src中的地址放到src的里面就好了

代码:

function loadImg($img){
//.attr(值)
//.attr(属性名称,值)
$img.attr('src', $img.attr('data-src')) //把data-src的值 赋值给src
$img.attr('data-isLoaded', 1) //已加载过的图片做标记
}

结果如下:

懒加载如何加载图片

如何判断一个元素出现在视野中?

元素相对顶点的距离(文字) <= 窗口高度 + 滚动的距离

代码:

function isShow($node){
return $node.offset().top <= $(window).height() + $(window).scrollTop()
}

结果如下:

懒加载判断一个元素出现在视野中
懒加载原理图解
懒加载原理图解

JS代码

start()
$(window).on('scroll', function(){
 start()
})

function start(){
  //.not('[data-isLoaded]')选中已加载的图片不需要重新加载
 $('.container img').not('[data-isLoaded]').each(function(){
   var $node = $(this)
   if( isShow($node) ){
     loadImg($node)
   }
 })
 }

//判断一个元素是不是出现在窗口(视野)
function isShow($node){
 return $node.offset().top <= $(window).height() + $(window).scrollTop()
 }
//加载图片
 function loadImg($img){
//.attr(值)
//.attr(属性名称,值)
$img.attr('src', $img.attr('data-src')) //把data-src的值 赋值给src
$img.attr('data-isLoaded', 1)//已加载的图片做标记
}

</script>

转载:https://www.cnblogs.com/moxiaowohuwei/p/7908877.html

炫意HTML5 » img 的data-src 属性及懒加载

CSS3教程HTML5教程