当前位置: 首页 > news >正文

别在用scroll去做懒加载了,交叉观察器轻松搞定

Ⅰ、前言

  • 懒加载是网页中非常 常见的;
  • 为了减少系统的压力,对于一些电商系统出场频率非常高;
  • 那么大家一般用什么方式去实现 懒加载 呢 ?

在这里插入图片描述
① 通过 scroll 的形式:

通过 滚动scroll事件,然后去判断距离,当 距离到达一定范围,判断是否要加载资源;


② 通过 IntersectionObserver 的形式:

通过 元素与设备视窗或者其他指定元素发生交集的时候 => 最底部的元素滚动到视口时 ,判断是否要加载资源;

优势:

  • IntersectionObserver不像scroll事件触发那么频繁 , 对系统压力更小 ;
  • 不用计算距离,使用起来更加简单 ;

Ⅱ、概念与用法

  • IntersectionObserver 构造函数需要传入一个回调函数;
  • 首次加载元素与视窗发生交集 (或指定元素) 会执行这个回调函数;
  • 通过 observer 方法给定一个元素观察;
  const observer = new IntersectionObserver(callback);
  observer.observe(dom);

Ⅲ、用交叉观察器实现懒加载

  • 首先我们创建 content 用存放内容,每次加载再向其中加入更多内容 ;
  • 用 交叉观察器(IntersectionObserver) 监听 <footer> 标签, 首次触发一下,当 <footer> 滚动到页面上时
  • 然后写一个 添加的方法(例 :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>
  • 查看效果 👇

在这里插入图片描述

  • 再添加一点样式 ,完整例子 👇
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</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>

在这里插入图片描述

相关文章:

  • 【C++】C++入门
  • 牛客网Python篇数据分析习题(五)
  • greenDao的使用文档
  • ubuntu 安装支持GPU的Docker详细步骤
  • 考研复试机试 | C++
  • 结构体熟练掌握--实现通讯录
  • IDEA配置部署tomcat详细步骤(maven web 和Javaweb)
  • 软件测试面试准备——(一)Selenium(1)基础问题及自动化测试
  • 【Unity3D】Shader常量、变量、结构体、函数
  • Android 逆向工具大整理,碉堡了
  • 【java】springboot和springcloud区别
  • Linux(Linux各目录结构详解)
  • 二进制 k8s 集群下线 master 组件流程分析和实践
  • pandas——字符串处理【建议收藏】
  • 机器学习基础总结
  • 前端高频面试题—JavaScript篇(二)
  • MongoDB--》MongoDB数据库以及可视化工具的安装与使用—保姆级教程
  • IC封装常见形式
  • 制作自己的ChatGPT
  • 数据结构与算法这么难,为什么我们还要学习?
  • 寻找“香奈儿”代工厂
  • 美伊第二轮核问题间接谈判结束,伊方称“结果是建设性的”
  • 对话地铁读书人|来自法学副教授的科普:读书日也是版权日
  • 美国防部宣布整合驻叙美军部队,将减少至不足千人
  • 泸州市长余先河已任四川省委统战部常务副部长
  • 突然手抖心慌?低血糖的“死亡连锁反应”,3步急救法必看