原生JS 实现吸顶效果的三种方式

本文介绍了使用原生JS实现吸顶效果的三种方法:监听全局scroll、intersectionObserver和CSS。对比了它们的优劣,指出intersectionObserver在快速滑动时可能存在的抖动问题,以及流畅度、性能和兼容性的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

〇、三种方法的优劣

intersectionObserver本以为是最优解,实现时发现效果并不好。
因为这个API的优先级比较低,每次都要等待页面渲染完成之后才能再次响应,所以在快速滑动的时候会出现抖动。

  1. 流畅度:CSS >= scroll > intersectionObserver
  2. 性能:CSS>= intersectionObserver >= scroll
  3. 兼容性:scroll > intersectionObserver > CSS

一、通过监听全局scroll实现

在这里插入图片描述

let reference = document.querySelector(".reference")
let nav = document.querySelector(".nav")
document.addEventListener("scroll",(e)=>{
  const distance = reference.getBoundingClientRect().top
  console.log(distance);
  if (distance<=0){
    nav.classList.add('fix')
  }else {
    nav.classList.remove('fix')
  }
})
<div class="box"></div>
<div class="reference">
  <div class="nav"></div>
</div>
<div class="box"></div>
*{
  padding: 0;
  margin: 0;
}
body{
  height: 1000px;
}
.reference {
  height: 100px;
  width: 100%;
  background-color: #ff2f45;
}
.nav {
  width: 100%;
  height: 100px;
  background-color: #ff2f45;
}
.box {
  width: 100px;
  height: 100px;
  background-color: blue;
}
.fix {
  position: fixed;
  top: 0;
}

二、通过 intersectionObserver 实现

在这里插入图片描述

let reference = document.querySelector(".reference")
let nav = document.querySelector(".nav")
let util = new IntersectionObserver((entries)=>{
  const entry = entries[0];
  console.log(entry.isIntersecting);
  if (entry.isIntersecting) {
    nav.classList.remove('fix')
  } else {
    nav.classList.add('fix')
  }
},{
  threshold: [1]
})
util.observe(reference)
<div class="box"></div>
<div class="reference">
  <div class="nav"></div>
</div>
<div class="box"></div>
*{
  padding: 0;
  margin: 0;
}
body{
  height: 1000px;
}
.reference {
  height: 100px;
  width: 100%;
  background-color: #ff2f45;
}
.nav {
  width: 100%;
  height: 100px;
  background-color: #ff2f45;
}
.box {
  width: 100px;
  height: 100px;
  background-color: blue;
}
.fix {
  position: fixed;
  top: 0;
}

三、通过CSS实现

在这里插入图片描述

<div class="box"></div>
<div class="reference">
  <div class="nav"></div>
</div>
<div class="box"></div>
*{
  padding: 0;
  margin: 0;
}
body{
  height: 1000px;
}
.reference {
  position: sticky;
  top: 0;
}
.nav {
  width: 100%;
  height: 100px;
  background-color: #ff2f45;
}
.box {
  width: 100px;
  height: 100px;
  background-color: blue;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值