当前位置:图趣网(Tuquu) > 网页设计教程 > 移动前端 > flex布局实现左侧笔墨溢出省略右侧笔墨自适应

使用智能 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标签始终高于 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,并可以使用它来为网页上的元素添加样式。

Live Demo on CodePen

以上就是本文的悉数内容,盼望对大家的学习有所帮助,也盼望大家多多支持图趣网。

[教程作者:佚名]
免责声明:本站文章系图趣网整理发布,如需转载,请注明出处,素材资料仅供个人学习与参考,请勿用于商业用途!
本文地址:http://www.tuquu.com/tutorial/wd496.html
用纯CSS实现镂空结果的示例代码
通过CSS变量修改样式的方法示例
图趣网微信
建议反馈
×