计算图片是否进入可视区
实现
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>图片懒加载</title>
<style>
img {
display: block;
width: 300px;
height: 300px;
margin-bottom: 20px;
}
</style>
</head>
<body>
<div>
<img data-src="./images/cherry.jpg" alt="">
<img data-src="./images/circle_copy.svg" alt="">
<img data-src="./images/person.png" alt="">
<img data-src="./images/circle.svg" alt="">
<img data-src="./images/person_copy.png" alt="">
<img data-src="./images/kiss.jpg" alt="">
<img data-src="./images/star.png" alt="">
<img data-src="./images/kiss_copy.jpg" alt="">
<img data-src="./images/star_copy.png" alt="">
<img data-src="./images/cherry_copy.jpg" alt="">
</div>
</body>
<script>
var imgs = document.querySelectorAll('img');
function offsetH(e) {
var height = e.offsetTop;
while(e = e.offsetParent) {
height += e.offsetTop;
}
return height;
}
function lazyLoad(imgs) {
function getViewport() {
let height;
if(window.innerHeight){
height = window.innerHeight;
}else if(document.compatMode === "BackCompat"){
height = document.body.clientHeight;
}else{
height = document.documentElement.clientHeight;
}
return height;
}
var viewportH =getViewport();
var scrollH = document.documentElement.scrollTop || document.body.scrollTop;
for (var i = 0; i < imgs.length; i++) {
if (viewportH + scrollH > offsetH(imgs[i])) {
imgs[i].src = imgs[i].getAttribute('data-src');
}
}
}
window.onload = window.onscroll = function () {
lazyLoad(imgs);
}
</script>
</html>