① 通过 scroll
的形式:
通过 滚动「
scroll
」事件,然后去判断距离,当 距离到达一定范围,判断是否要加载资源;
② 通过 IntersectionObserver
的形式:
通过 元素与设备视窗或者其他指定元素发生交集的时候 => 「最底部的元素滚动到视口时」 ,判断是否要加载资源;
优势:
IntersectionObserver
」不像「scroll
」事件触发那么频繁 , 对系统压力更小 ;IntersectionObserver
构造函数需要传入一个回调函数;observer
方法给定一个元素观察; const observer = new IntersectionObserver(callback);
observer.observe(dom);
content
用存放内容,每次加载再向其中加入更多内容 ;IntersectionObserver
) 监听
标签, 首次触发一下,当
滚动到页面上时addItem
),每次添加10条内容;<body>
<div class="content">div>
<footer> 加载中。。。 footer>
body>
<script>
const footer = document.getElementsByTagName('footer')[0]
const observer = new IntersectionObserver((val) => {
addItem();
});
observer.observe(footer);
const content = document.getElementsByClassName('content')[0]
let num = 0;
function addItem() {
for (let i = num; i < num+10; i++) {
let node = document.createElement("div");
node.innerText = `第${i+1}列`
node.className = 'item'
box.appendChild(content)
}
num = num + 10;
}
script>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Documenttitle>
head>
<style>
.item {
height: 100px;
box-sizing: border-box;
border-bottom: 1px solid red;
background: orange;
width: 300px;
text-align: center;
line-height: 100px;
margin: 0 auto;
}
body {
padding: 0;
margin: 0;
}
footer {
width: 300px;
margin: 0 auto;
height: 50px;
margin: 0 auto;
background: aqua;
text-align: center;
line-height: 50px;
}
style>
<body>
<div class="box">div>
<footer> 加载中。。。 footer>
body>
<script>
const footer = document.getElementsByTagName('footer')[0]
const observer = new IntersectionObserver((val) => {
setTimeout(addItem, 300);
});
observer.observe(footer);
const box = document.getElementsByClassName('box')[0]
let num = 0;
function addItem() {
for (let i = num; i < num + 10; i++) {
let node = document.createElement("div");
node.innerText = `第${i + 1}列`
node.className = 'item'
box.appendChild(node)
}
num = num + 10;
}
script>
html>