首页前端开发CSSCSS实现基于用户滚动应用

CSS实现基于用户滚动应用

时间2024-05-26 05:58:03发布访客分类CSS浏览932
导读: 通过将当前滚动偏移映射到html元素上的属性,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动导航组件。 这是我们将使用的HTML,当我们向下滚动时,我们希望在内容之上浮动的一个很好的组件。 I'm...
  通过将当前滚动偏移映射到html元素上的属性,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动导航组件。   这是我们将使用的HTML,当我们向下滚动时,我们希望在内容之上浮动的一个很好的组件。   I'mthepageheader   

Lot'sofcontenthere...

  

Morebeautifulcontent...

  

Content...

  首先,我们将监听该'scroll'事件,document并且scrollY每次用户滚动时我们都会请求当前位置。   document.addEventListener('scroll',()=> {   document.documentElement.dataset.scroll=window.scrollY;   } );   我们将滚动位置存储在html元素的数据属性中。如果您使用开发工具查看DOM,它将如下所示。      现在我们可以使用此属性来设置页面上的元素样式。      /*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} );




本文转载自中文网


声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: CSS实现基于用户滚动应用
本文地址: https://pptw.com/jishu/668272.html
如何在html中更改行间距 flex作用于box容器上的属性介绍

游客 回复需填写必要信息