如何使用CSS3来实现滚动视差效果

发布时间:2021-08-04 17:50:43 作者:chen
来源:亿速云 阅读:119

本篇内容主要讲解“如何使用CSS3来实现滚动视差效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用CSS3来实现滚动视差效果”吧!


在web设计中,最常见的实现视差效果的方式是使用jQuery插件。但这种方法有一些弊端。这些插件大多都是在window对象的scroll事件上放置监听器。这会导致JavaScript需要处理大量的事件触发(处理scroll事件很容易造成浏览器性能问题,使用时需要非常小心。)移动不同的层,计算背景的位置,设置图片的属性,这都引起了大量的DOM操作。

简言之,使用JavaScript来实现视差效果会让页面的滚动出现性能问题,出现卡顿。

background-attachment属性回顾
background-attachment -- 定义背景图片随滚动轴的移动方式
取值: scroll | fixed | inherit
scroll: 随着页面的滚动轴背景图片将移动
fixed: 随着页面的滚动轴背景图片不会移动
inherit: 继承
初始值: scroll
继承性: 否
适用于: 所有元素
background:背景.attachment:附着.
示例

CSS Code复制内容到剪贴板

  1. body    

  2. {   

  3.  background-image:url('list-orange.png');   

  4.  background-attachment:fixed;   

  5.  background-repeat:repeat-x;   

  6.  background-position:center center;   

  7. }  

屏幕的背景图片为一条橙色线.随着滚动轴移动,橙色线的视觉位置不变.
CSS background-attachment 属性示例

使用background-attachment: fixed实现视差效果

为什么只有一小部分人知道,这种效果实际上可以用CSS实现。

为了实现视差效果,多个背景图片必须放置在不同的元素上。这些背景图需要定义成background-attachment: fixed。通过设定background-attachment,我们可以改变背景图像的效果和位置。

background-attachment的缺省值是scroll,也就是背景图片和内容的位置是相对静止的。这我们大家都见过,当我们上下滚动一个网页时,背景和内容一起滚动。

当把background-attachment设置成fixed时,事情会变得有趣。fixed是说背景图片不随内容一起滚动,而是跟窗口保持静止。也就是说,当你拖动滚动条时,背景图片没有变化。这就能够产生漂亮的视差效果。

让我看一个实际实现:

CSS Code复制内容到剪贴板

  1. <!-- Four containers for setting the background images -->   

  2. <div class="parallax">   

  3.   <div class="bg__foo">foo</div>   

  4.   <div class="bg__bar">bar</div>   

  5.   <div class="bg__baz">baz</div>   

  6.   <div class="bg__bazz">bazz</div>   

  7. </div>   

  8. // setting base styles to image containers   

  9. [class*="bg__"] {   

  10.   height: 50vh;   

  11.   

  12.   text-indent: -9999px;   

  13.   

  14.   /* fix background */  

  15.   background-attachmentfixed;   

  16.   

  17.   /* center it */  

  18.   background-positioncenter center;   

  19.   

  20.   /* Scale it nicely to the element */  

  21.   background-size: cover;   

  22.   

  23.   /* just make it look a bit better  */  

  24.   &:nth-child(2n) {   

  25.     box-shadow: inset 0 0 1em #111;   

  26.   }   

  27. }   

  28.   

  29. .bg__foo {   

  30.   background-imageurl(   

  31.     https://cache.yisu.com/upload/information/20210311/295/12388.jpg   

  32.   );   

  33. }   

  34.   

  35. .bg__bar {   

  36.   background-imageurl(   

  37.     https://cache.yisu.com/upload/information/20210311/295/12389.jpg   

  38.   );   

  39. }   

  40.   

  41. .bg__baz {   

  42.   background-imageurl(   

  43.     https://cache.yisu.com/upload/information/20210311/295/12390.jpg   

  44.   );   

  45. }   

  46.   

  47. .bg__bazz {   

  48.   height: 100vh;   

  49.   

  50.   background-imageurl(   

  51.     https://cache.yisu.com/upload/information/20210311/295/12388.jpg   

  52.   );   

  53. }  

关于这种技术的浏览器兼容情况,你可以参考这里,基本上,现代浏览器和IE9+的浏览器都支持。


观看演示


对我个人而言,我更喜欢CSS技术实现的视差效果,而不是用JavaScript。用CSS实现,是受浏览器原生支持,没有编程逻辑,没有对DOM额外的操作,使得整个方案非常的简洁漂亮。

即使是CSS实现的视差效果,也会给浏览器带来负担。

background-attachment: fixed会导致浏览器更多的渲染,也会影响浏览器滚动的效率。所以,开发时一定要多做测试,视性能情况而决定实现的效果。

到此,相信大家对“如何使用CSS3来实现滚动视差效果”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. 推荐六款帮助你实现惊艳视差滚动效果的 jQuery 插件
  2. 基于jQuery和CSS3实现APPLE TV海报视差效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

css 视差

上一篇:mysql中怎么配置慢查询

下一篇:如何解决某些HTML字符打不出来的问题

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》