使用CSS 怎么实现用户滚动位置应用样式
今天就跟大家聊聊有关使用CSS 怎么实现用户滚动位置应用样式,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
通过将当前滚动偏移量添加到到 html 元素的属性上,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动在页面顶部的导航组件。
这是我们将使用的 HTML,<header> 组件是我们希望当我们向下滚动时,始终浮动在页面顶部的一个组件。
<header>I'm the page header</header><p>Lot's of content here...</p><p>More beautiful content...</p><p>Content...</p>
首先,我们将监听 document 上的 'scroll' 事件,并且每次用户滚动时我们都会取出当前的 scrollY 值。
document.addEventListener('scroll', () => { document.documentElement.dataset.scroll = window.scrollY;});
我们将滚动位置存储在 html 元素的数据属性中。如果您使用开发工具查看 DOM,它将如下所示:<html data-scroll="0">
现在我们可以使用此属性来设置页面上的元素样式。
header { min-height: 3em; width: 100%; background-color: #fff;}html:not([data-scroll='0']) body { padding-top: 3em;}html:not([data-scroll='0']) header { position: fixed; top: 0; z-index: 1; box-shadow: 0 0 .5em rgba(0, 0, 0, .5);}
基本上就是这样,当用户向下滚动时,header 标签将自动从页面中分离并浮动在内容之上。JavaScript 代码并不关心这一点,它的任务就是将滚动偏移量放在数据属性中。这很完美,因为 JavaScript 和 CSS 之间没有紧密耦合。
但仍有一些可以改进的地方,主要是在性能方面。
首先,我们必须修改 JavaScript 脚本,以适应页面加载时滚动位置不在顶部的情况。在这样的情况下,header 标签将呈现错误的样式。
页面加载时,我们必须快速获取当前的滚动偏移量,这样确保了我们始终与当前的页面的状态同步。
// 读出当前页面的滚动位置并将其存入 document 的 data 属性中// 因此我们就可以在我们的样式表中使用它const storeScroll = () => { document.documentElement.dataset.scroll = window.scrollY;}// 监听滚动事件document.addEventListener('scroll', storeScroll);// 第一次打开页面时就更新滚动位置storeScroll();
接下来我们将看一些性能方面改进。如果我们想要获取 scrollY 滚动位置,浏览器将必须计算页面上每个元素的位置,以确保它返回正确的位置。如果我们不强制它每次滚动都取值才是最好的做法。
要做到这一点,我们需要一个 debounce(防抖动)方法,这个方法会将我们的取值请求加入一个队列中,在浏览器准备好绘制下一帧之前都不会重新取值,此时它已经计算出了页面上所有元素的位置,所以它不会不断重复相同的工作。
// 防抖动函数接受一个我们自定义的函数作为参数const debounce = (fn) => { // 这包含了对 requestAnimationFrame 的引用,所以我们可以在我们希望的任何时候停止它 let frame; // 防抖动函数将返回一个可以接受多个参数的新函数 return (...params) => { // 如果 frame 的值存在,那就清除对应的回调 if (frame) { cancelAnimationFrame(frame); } // 使我们的回调在浏览器下一帧刷新时执行 frame = requestAnimationFrame(() => { // 执行我们的自定义函数并传递我们的参数 fn(...params); }); } };// Reads out the scroll position and stores it in the data attribute// so we can use it in our stylesheetsconst storeScroll = () => { document.documentElement.dataset.scroll = window.scrollY;}// Listen for new scroll events, here we debounce our `storeScroll` functiondocument.addEventListener('scroll', debounce(storeScroll));// Update scroll position for first timestoreScroll();
通过标记事件为 passive 状态,我们可以告诉浏览器我们的滚动事件不会被触摸交互阻止(例如与谷歌地图等插件交互时)。这允许浏览器立即滚动页面,因为它现在知道该事件不会被阻止。
document.addEventListener('scroll', debounce(storeScroll), { passive: true });
解决了性能问题后,我们现在可以通过稳定的方式使用 JavaScript 将获取的数据提供给 CSS,并可以使用它来为页面上的元素添加样式。
看完上述内容,你们对使用CSS 怎么实现用户滚动位置应用样式有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341