您现在的位置是:网站首页> 编程资料编程资料
使用智能 CSS 基于用户滚动位置应用样式CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
2021-09-04
1027人已围观
简介 这篇文章主要介绍了使用智能 CSS 基于用户滚动位置应用样式的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
通过将当前滚动偏移量添加到到 html 元素的属性上,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动在页面顶部的导航组件。
这是我们将使用的 HTML,
I'm the page header Lot's of content here...
More beautiful content...
Content...
首先,我们将监听 document 上的 'scroll' 事件,并且每次用户滚动时我们都会取出当前的 scrollY 值。
document.addEventListener('scroll', () => { document.documentElement.dataset.scroll = window.scrollY; }); 我们将滚动位置存储在 html 元素的数据属性中。如果您使用开发工具查看 DOM,它将如下所示:
现在我们可以使用此属性来设置页面上的元素样式。
/* 保证 header标签始终高于 3em */ header { min-height: 3em; width: 100%; background-color: #fff; } /* 在页面顶部保留与 header 的 min-height 相同的高度 */ html:not([data-scroll='0']) body { padding-top: 3em; } /* 将 header 标签切换成 fixed 定位模式,并且将它固定在页面顶部 */ html:not([data-scroll='0']) header { position: fixed; top: 0; z-index: 1; /* box-shadow 属性能够增强浮动的效果 */ 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 stylesheets const storeScroll = () => { document.documentElement.dataset.scroll = window.scrollY; } // Listen for new scroll events, here we debounce our `storeScroll` function document.addEventListener('scroll', debounce(storeScroll)); // Update scroll position for first time storeScroll();通过标记事件为 passive 状态,我们可以告诉浏览器我们的滚动事件不会被触摸交互阻止(例如与谷歌地图等插件交互时)。这允许浏览器立即滚动页面,因为它现在知道该事件不会被阻止。
document.addEventListener('scroll', debounce(storeScroll), { passive: true });解决了性能问题后,我们现在可以通过稳定的方式使用 JavaScript 将获取的数据提供给 CSS,并可以使用它来为页面上的元素添加样式。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- 通过CSS变量修改样式的方法示例你真的需要了解一下CSS变量 var()的用法css文件中的样式类被覆盖,js文件中的变量未定义问题CSS变量对JS交互组件开发带来的提升与变革示例代码详解
- css加载会造成阻塞吗浅谈CSS到底会不会阻塞页面渲染详解css加载会造成阻塞吗浅谈css动画是否会被js阻塞
- css动画属性使用及实例代码(transition/transform/animation) 基于CSS3的animation属性实现微信拍一拍动画效果CSS3动画之利用requestAnimationFrame触发重新播放功能CSS3中动画属性transform、transition和animation属性的区别css动画效果之animation的常用样式
- 基于CSS 属性实现按钮悬停边框和背景动画集合CSS 制作带边框背景色透明的消息框css3 边框、背景、文本效果的实现代码CSS3实现多背景模拟动态边框的效果CSS控制背景图像平铺实现边框阴影效果css div 边框阴影利用背景图或内外层div实现层次感觉阴影效果css样式div或li在ie6下背景平铺及border边框断线解决技巧 CSS新特性:圆角边框多栏Gird布局背景设置css背景和边框标签实例详解
- 详解解决flex布局的justify-content: space-between对齐方式的一个BUG的两种方法详解CSS中的display:flex||inline-flex属性解决display:flex属性 justify-content: space-between换行后的排版问
- 详解在CSS中解决内容过长的问题css 实现文字过长自动隐藏功能CSS实现标题文字过长部分显示省略号的方法pre标签的css代码,防止代码pre中代码过长等问题字符串过长CSS截取多余文字并用省略号显示CSS解决无空格的字母、数字过长不自动换行的问题
- css实现虚线边框滚动效果的实例代码CSS3 边框效果css效果之边框内圆角CSS揭秘之多重边框的实现css3实现六边形边框的实例代码纯css实现动态边框的示例代码基于CSS 属性实现按钮悬停边框和背景动画集合CSS边框长度控制功能的实现
- css3实现可拖动的魔方3d效果 CSS3 SVG实现的复古粽子魔方变换动画特效源码CSS3实现3D视觉旋转魔方动画特效源码纯CSS3 3D魔方翻转动画特效源码
- css性能优化-will-change使用详解CSS前端页面渲染优化属性will-change的具体使用
- CSS实现垂直居中的七个方法实例代码详解
