检查元素是否在屏幕可见区域内(自用笔记)

获取一个元素的显示次数可以通过IntersectionObserver实现

html代码

<div class="tips">box is visible</div>
<div class="box">box</div>

js代码

<script>
  const $tips = document.querySelector('.tips')
  const callback = (entries) => {
    entries.forEach((entry) => {
      console.log(entry.intersectionRatio)
      if (entry.intersectionRatio > 0) {
        $tips.innerHTML = 'box is visible'
      } else if (entry.intersectionRatio <= 0) {
        $tips.innerHTML = 'box is hidden'
      }
    });
  }

  const options = {
    // A list of thresholds, sorted in increasing numeric order, where each threshold is a ratio of intersection area to bounding box area of an observed target. Notifications for a target are generated when any of the thresholds are crossed for that target. If no value was passed to the constructor, 0 is used.
    // threshold: 1,
  }
  const observer = new IntersectionObserver(callback, options)
  observer.observe(document.querySelector('.box'))
</script>```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值