<sup id="sjju3"><noscript id="sjju3"></noscript></sup>
    <big id="sjju3"></big>

  • <blockquote id="sjju3"></blockquote>
    <blockquote id="sjju3"></blockquote>

      <td id="sjju3"></td>

      <big id="sjju3"></big>
        <code id="sjju3"><strong id="sjju3"><dl id="sjju3"></dl></strong></code>
      1. 使用智能 CSS 基于用户滚动位置应用样式

          发布时间:2019-02-18 16:43:45   作者:jerryOnlyZRJ   我要评论

        这篇文章主要介绍了使用智能 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' 事件,并且?#30475;?#29992;户滚动时我们都会取出当前的 scrollY 值。

        document.addEventListener('scroll', () => {
          document.documentElement.dataset.scroll = window.scrollY;
        });
        

        我们将滚动位置存储在 html 元素的数据属性?#23567;?#22914;果您使用开发工具查看 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 代码并不关心这一点,它的任务就是将滚动偏移量放在数据属性?#23567;?#36825;很完美,因为 JavaScript 和 CSS 之间没有紧密耦合。

        但仍有一些可以改进的地方,主要是在性能方面。

        首先,我们必须修改 JavaScript 脚本,以适应页面加载时滚动位置不在顶部的情况。在这样的情况下,header 标签将呈现错误的样式。

        页面加载时,我们必须快速获取当前的滚动偏移量,这样确保了我们始终与当前的页面的状态同步。

        // 读出当前页面的滚动位置并将其存入 document 的 data 属性中
        // 因此我们就可以在我们的样式表中使用它
        const storeScroll = () => {
          document.documentElement.dataset.scroll = window.scrollY;
        }
        
        // 监听滚动事件
        document.addEventListener('scroll', storeScroll);
        
        // 第一次打开页面?#26412;?#26356;新滚动位置
        storeScroll();
        

        接下来我们将看一些性能方面改进。如果我们想要获取 scrollY 滚动位置,浏览器将必须计算页面上每个元素的位置,以确保它返回正确的位置。如果我们不强制它?#30475;?#28378;动都取值才是最好的做法。

        要做到这一点,我们需要一个 debounce(防抖动)方法,这个方法会将我们的取值请求加入一个队列中,在浏览器准备?#27809;?#21046;下一帧之前都不会重新取值,此时它已经计算出了页面上所有元素的位置,所?#36816;?#19981;会不?#29616;?#22797;相同的工作。

        // 防抖动函数接受一个我们自定义的函数作为参数
        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 状态,我们可以告诉浏览器我们的滚动事件不会被触摸交互阻止(例如与谷歌地图等插件交互时)。这允许浏览器立即滚动页面,因为它现在知?#26639;?#20107;件不会被阻止。

        document.addEventListener('scroll', debounce(storeScroll), { passive: true });

        解决了性能问题后,我们现在可以通过稳定的方式使用 JavaScript 将获取的数据提供给 CSS,并可以使用它来为页面上的元素添加样式。

        Live Demo on CodePen

        以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

        相关文章

        • ?#31243;窩SS中?#24515;?#22411;的理解

          这篇文章主要介绍了?#31243;窩SS中?#24515;?#22411;的理解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
          2019-02-19
        • 使用智能 CSS 基于用户滚动位置应用样式

          这篇文章主要介绍了使用智能 CSS 基于用户滚动位置应用样式的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
          2019-02-18
        • 通过CSS变量修改样式的方法示例

          这篇文章主要介绍了通过CSS变量修改样式的方法示例的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
          2019-02-15
        • 如何使用css绘制钻石的方法

          这篇文章主要介绍了如何使用css绘制钻石的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习
          2019-02-15
        • css的content属性的具体使用

          这篇文章主要介绍了css的content属性的具体使用,用于呈现伪元素的内容。平时content属性值我们用的最多的就是给个纯字符,其实它还有很多值可供选择。?#34892;?#36259;的可以了解一
          2019-02-14
        • css加载会造成阻塞吗

          可能大家都知道,js执行会阻塞DOM树的解析和渲染,那么css加载会阻塞DOM树的解析和渲染吗?下面就跟随小编一起来了解一下
          2019-02-13
        • css隐藏移动端滚动条并且ios上平滑滚动的方法

          这篇文章主要介绍了css隐藏移动端滚动条并且ios上平滑滚动的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
          2019-01-23
        • css多种方式实现等宽布局的示例代码

          本文讲的等宽布局是在不手动设置元素宽度的情况下,使用纯css实现各个元素宽度都相当的效果。具有一定的参考价值,?#34892;?#36259;的小伙伴们可以参?#23478;?#19979;
          2019-01-22
        • 纯CSS实现表单验证的示例代码

          这篇文章主要介绍了纯CSS实现表单验证的示例代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
          2019-01-21
        • 详解利用clear清除浮动的一些问题解决

          这篇文章主要介绍了详解利用clear清除浮动的一些问题解决的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
          2019-01-18

        最新评论

        2018白小姐一肖中特马
        <sup id="sjju3"><noscript id="sjju3"></noscript></sup>
        <big id="sjju3"></big>

      2. <blockquote id="sjju3"></blockquote>
        <blockquote id="sjju3"></blockquote>

          <td id="sjju3"></td>

          <big id="sjju3"></big>
            <code id="sjju3"><strong id="sjju3"><dl id="sjju3"></dl></strong></code>
          1. <sup id="sjju3"><noscript id="sjju3"></noscript></sup>
            <big id="sjju3"></big>

          2. <blockquote id="sjju3"></blockquote>
            <blockquote id="sjju3"></blockquote>

              <td id="sjju3"></td>

              <big id="sjju3"></big>
                <code id="sjju3"><strong id="sjju3"><dl id="sjju3"></dl></strong></code>