JS:IntersectionObserver(监听目标元素是否出现在窗口中)

一、简介

IntersectionObserver 是 JavaScript 中的一个 API,用于异步观察目标元素与其祖先元素或顶级文档视口的交叉状态。当目标元素的可见性发生变化时,你可以使用 IntersectionObserver 来执行某些操作,比如懒加载图片、无限滚动等。 new IntersectionObserver() 是用于创建一个新的 IntersectionObserver 实例的构造函数。当你调用这个构造函数时,你需要传递一个回调函数作为参数,这个回调函数会在交叉状态变化时被调用。

简单的说,这个API能够帮你检测一个元素是否出现在视窗中,从而实现需要的交互效果。

二、基础应用

在下面的代码中,被监测的div每次出现在可视窗口中时都会打印一次"div 现在在视窗中!"

当然,下面的代码会出现滚动条,但是如果不可见,依然算作与视窗无交叉。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>IntersectionObserver 监听 div 是否在视窗中</title>
    <style>
      #monitored-div {
        width: 200px;
        height: 200px;
        background-color: lightblue;
        position: absolute;
        left: 100px;
        top: calc(100vh - 200px);
        animation: move 5s infinite;
      }
      @keyframes move {
        0% {
          top: calc(100vh - 200px);
        }
        50% {
          top: 120vh;
        }
        100% {
          top: calc(100vh - 200px);
        }
      }
    </style>
  </head>
  <body>
    <div id="monitored-div">我是被监听的 div</div>

    <script>
      // 获取被监听的 div
      const monitoredDiv = document.getElementById("monitored-div");

      // 创建一个 IntersectionObserver 实例
      const observer = new IntersectionObserver(
        (entries, observer) => {
          entries.forEach((entry) => {
            // 检查 entry.isIntersecting 是否为 true
            if (entry.isIntersecting) {
              console.log("div 现在在视窗中!");
            } else {
              console.log("div 不在视窗中。");
            }
          });
        },
        { threshold: 0.1 }
      ); // 这里的 threshold 表示目标元素与视窗的交叉比例达到 10% 时就触发回调函数

      // 开始观察 monitoredDiv
      observer.observe(monitoredDiv);
    </script>
  </body>
</html>

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值