• 紫光阁中共中央国家机关工作委员会 2020-02-23
  • 看见什么有用?[猜想] 2020-02-23
  • 中办印发《关于进一步激励广大干部新时代新担当新作为的意见》 2019-09-07
  • 一条塔里木河 串起南疆各色景致与无限风光 2019-09-07
  • 【互动话题】我为两会建言献策 2019-07-18
  • 还是中国足球队最牛,因为他稳定;中国股市就不一样了,怎么形容呢?唉,还不如中国足球! 2019-07-18
  • 新生代农民工市民化与城镇化发展 2019-07-04
  • 习近平应约同俄罗斯总统普京通电话 2019-07-02
  • 中粮集团混改再按“快进键” 2019-07-02
  • 人的本质,要能反映出人与动物的本质不同。过去有个网友说“劳动是人的本质”;真理先生现说是“财富占有”!???,能解释一下么? 2019-06-30
  • [鄙视]又一个“风水帖”。深坛什么时候成了“算命平台”了?!这些伪公知砖家不深入农村了解农民,凭一点表象就信口开河,“辛苦劳作的农民没有富起来”是这“4点原因” 2019-06-22
  • 击鼓-热门标签-华商生活 2019-06-22
  • 河北定州:秸秆回收变废为宝 2019-05-14
  • 妹妹半个多世纪前嫁到安徽 八旬老人想再见她一面 2019-05-14
  • 在这里,读懂2017——人民日报十大评论文章 2019-05-14
  • 欢迎来到DIVCSS5查找CSS资料与学习DIV CSS布局技术!
      通过将当前滚动偏移映射到html元素上的属性,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动导航组件。
     
      这是我们将使用的HTML,<header>当我们向下滚动时,我们希望在内容之上浮动的一个很好的组件。
     
      <header>I'mthepageheader</header>
     
      <p>Lot'sofcontenthere...</p>
     
      <p>Morebeautifulcontent...</p>
     
      <p>Content...</p>
     
      首先,我们将监听该'scroll'事件,document并且scrollY每次用户滚动时我们都会请求当前位置。
     
      document.addEventListener('scroll',()=>{
     
      document.documentElement.dataset.scroll=window.scrollY;
     
      });
     
      我们将滚动位置存储在html元素的数据属性中。如果您使用开发工具查看DOM,它将如下所示。
     
      <htmldata-scroll="0">
     
      现在我们可以使用此属性来设置页面上的元素样式。
     
      
     
      /*Makesuretheheaderisalwaysatleast3emhigh*/
     
      header{
     
      min-height:3em;
     
      width:100%;
     
      background-color:#fff;
     
      }
     
      /*Reservethesameheightatthetopofthepageastheheadermin-height*/
     
      html:not([data-scroll='0'])body{
     
      padding-top:3em;
     
      }
     
      /*Switchtofixedpositioning,andsticktheheadertothetopofthepage*/
     
      html:not([data-scroll='0'])header{
     
      position:fixed;
     
      top:0;
     
      z-index:1;
     
      /*Thisbox-shadowwillhelpsellthefloatingeffect*/
     
      box-shadow:00.5emrgba(0,0,0,.5);
     
      }
     
      基本上就是这样,当向下滚动时,标题现在将自动从页面中分离并浮动在内容之上。JavaScript代码并不关心这一点,它的任务就是将滚动偏移量放在数据属性中。这很好,因为JavaScript和CSS之间没有紧密耦合。
     
      仍有一些改进,主要是在性能领域。
     
      但首先,我们必须修复脚本,以适应页面加载时滚动位置不在顶部的情况。在这些情况下,标题将呈现错误。
     
      页面加载时,我们必须快速获取当前滚动偏移量。这确保了我们始终与当前的事态同步。
     
      //Readsoutthescrollpositionandstoresitinthedataattribute
     
      //sowecanuseitinourstylesheets
     
      conststoreScroll=()=>{
     
      document.documentElement.dataset.scroll=window.scrollY;
     
      }
     
      //Listenfornewscrollevents
     
      document.addEventListener('scroll',storeScroll);
     
      //Updatescrollpositionforfirsttime
     
      storeScroll();
     
      接下来我们将看一些性能改进。如果我们请求该scrollY位置,浏览器将必须计算页面上每个元素的位置,以确保它返回正确的位置。如果我们不强迫它每次滚动互动都这样做是最好的。
     
      要做到这一点,我们需要一个debounce方法,这个方法会将我们的请求排队,直到浏览器准备好绘制下一帧,此时它已经计算了页面上所有元素的位置,所以它不会再来一遍。
     
      
     
      
     
      //Thedebouncefunctionreceivesourfunctionasaparameter
     
      constdebounce=(fn)=>{
     
      //ThisholdstherequestAnimationFramereference,sowecancancelitifwewish
     
      letframe;
     
      //Thedebouncefunctionreturnsanewfunctionthatcanreceiveavariablenumberofarguments
     
      return(...params)=>{
     
      //Iftheframevariablehasbeendefined,clearitnow,andqueuefornextframe
     
      if(frame){
     
      cancelAnimationFrame(frame);
     
      }
     
      //Queueourfunctioncallforthenextframe
     
      frame=requestAnimationFrame(()=>{
     
      //Callourfunctionandpassanyparamswereceived
     
      fn(...params);
     
      });
     
      }
     
      };
     
      //Readsoutthescrollpositionandstoresitinthedataattribute
     
      //sowecanuseitinourstylesheets
     
      conststoreScroll=()=>{
     
      document.documentElement.dataset.scroll=window.scrollY;
     
      }
     
      //Listenfornewscrollevents,herewedebounceour`storeScroll`function
     
      document.addEventListener('scroll',debounce(storeScroll));
     
      //Updatescrollpositionforfirsttime
     
      storeScroll();
     
      通过标记事件,passive我们可以告诉浏览器我们的滚动事件不会被触摸交互取消(例如与谷歌地图等插件交互时)。这允许浏览器立即滚动页面,因为它现在知道该事件不会被取消。
     
      document.addEventListener('scroll',debounce(storeScroll),{passive:true});




    本文转载自中文网


     

    时时彩走势图后一 www.cuhw.com.cn 如需转载,请注明文章出处和来源网址:http://www.cuhw.com.cn/jiqiao/j54117.shtml

  • 紫光阁中共中央国家机关工作委员会 2020-02-23
  • 看见什么有用?[猜想] 2020-02-23
  • 中办印发《关于进一步激励广大干部新时代新担当新作为的意见》 2019-09-07
  • 一条塔里木河 串起南疆各色景致与无限风光 2019-09-07
  • 【互动话题】我为两会建言献策 2019-07-18
  • 还是中国足球队最牛,因为他稳定;中国股市就不一样了,怎么形容呢?唉,还不如中国足球! 2019-07-18
  • 新生代农民工市民化与城镇化发展 2019-07-04
  • 习近平应约同俄罗斯总统普京通电话 2019-07-02
  • 中粮集团混改再按“快进键” 2019-07-02
  • 人的本质,要能反映出人与动物的本质不同。过去有个网友说“劳动是人的本质”;真理先生现说是“财富占有”!???,能解释一下么? 2019-06-30
  • [鄙视]又一个“风水帖”。深坛什么时候成了“算命平台”了?!这些伪公知砖家不深入农村了解农民,凭一点表象就信口开河,“辛苦劳作的农民没有富起来”是这“4点原因” 2019-06-22
  • 击鼓-热门标签-华商生活 2019-06-22
  • 河北定州:秸秆回收变废为宝 2019-05-14
  • 妹妹半个多世纪前嫁到安徽 八旬老人想再见她一面 2019-05-14
  • 在这里,读懂2017——人民日报十大评论文章 2019-05-14