提供Discuz ,ECShop ,PHPCMS ,帝国CMS ,CSS教程 ,PHP教程 ,DedeCMS ,WordPress ,HTML教程等cms问题查询.
当前位置: CSS教程 > CSS完成基于用户转动运用(代码)【css教程】,css3,javascript

本篇文章给人人带来的内容是关于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>

起首,我们将监听该'scroll'事宜,document而且scrollY每次用户转动时我们都邑要求当前位置。

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

我们将转动位置存储在html元素的数据属性中。假如您运用开发工具检察DOM,它将以下所示。

<html data-scroll="0">

如今我们能够运用此属性来设置页面上的元素款式。

/* Make sure the header is always at least 3em high */
header {
  min-height: 3em;
  width: 100%;
  background-color: #fff;
}

/* Reserve the same height at the top of the page as the header min-height */
html:not([data-scroll='0']) body {
  padding-top: 3em;
}

/* Switch to fixed positioning, and stick the header to the top of the page */
html:not([data-scroll='0']) header {
  position: fixed;
  top: 0;
  z-index: 1;

  /* This box-shadow will help sell the floating effect */
  box-shadow: 0 0 .5em rgba(0, 0, 0, .5);
}

基本上就是如许,当向下转动时,题目如今将自动从页面中星散并浮动在内容之上。JavaScript代码并不体贴这一点,它的使命就是将转动偏移量放在数据属性中。这很好,由于JavaScript和CSS之间没有严密耦合。

仍有一些革新,主假如在机能范畴。

但起首,我们必需修复剧本,以顺应页面加载时转动位置不在顶部的状况。在这些状况下,题目将显现毛病。

页面加载时,我们必需疾速猎取当前转动偏移量。这确保了我们一直与当前的局势同步。

// 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
document.addEventListener('scroll', storeScroll);

// Update scroll position for first time
storeScroll();

接下来我们将看一些机能革新。假如我们要求该scrollY位置,浏览器将必需盘算页面上每一个元素的位置,以确保它返回准确的位置。假如我们不强制它每次转动互动都如许做是最好的。

要做到这一点,我们须要一个debounce要领,这个要领会将我们的要求列队,直到浏览器准备好绘制下一帧,此时它已盘算了页面上一切元素的位置,所以它不会再来一遍。

// The debounce function receives our function as a parameter
const debounce = (fn) => {

  // This holds the requestAnimationFrame reference, so we can cancel it if we wish
  let frame;

  // The debounce function returns a new function that can receive a variable number of arguments
  return (...params) => {
    
    // If the frame variable has been defined, clear it now, and queue for next frame
    if (frame) { 
      cancelAnimationFrame(frame);
    }

    // Queue our function call for the next frame
    frame = requestAnimationFrame(() => {
      
      // Call our function and pass any params we received
      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 });

本篇文章到这里就已悉数完毕了,更多其他精彩内容能够关注ki4网的CSS视频教程栏目!

以上就是CSS完成基于用户转动运用(代码)的细致内容,更多请关注ki4网别的相干文章!

「梦想一旦被付诸行动,就会变得神圣,如果觉得我的文章对您有用,请帮助本站成长」

分享到:
赞(0) 打赏

支付宝扫一扫打赏

微信扫一扫打赏

标签:

上一篇:

下一篇:

相关推荐

0 条评论关于"CSS完成基于用户转动运用(代码)【css教程】,css3,javascript"

最新评论

    暂无留言哦~~

博客简介

看古风美女插画Cos小姐姐,素材合集图集打包下载:炫龙网,好看二次元插画应有尽有,唯美小姐姐等你来。

友情链接

他们同样是一群网虫,却不是每天泡在网上游走在淘宝和网游之间、刷着本来就快要透支的信用卡。他们或许没有踏出国门一步,但同学却不局限在一国一校,而是遍及全球!申请交换友链

服务热线:
 

 QQ在线交流

 旺旺在线