好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-小tip: 纯CSS实现视差滚动效果

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

video{object-fit:contain;width:100%;max-width:1116px;height:auto;border:1px solid #ccc;margin:1em 0;}

一、效果Demo先行~

视差滚动效果大家可能都听过,基本上都是JS实现的,有对应插件 – Parallax.js.

实际上,如果你对兼容性要求不是很高,比方说忽略IE浏览器,则我们使用简单的几行 CSS 代码就可以实现视差滚动效果了。

对于效果展示,先看效果是最能引起兴趣,激发学习热情的,如下(IE9+):

您可以狠狠地点击这里:纯CSS实现的视差滚动效果Demo

进入Demo滚动滚动条,最好鼠标慢慢拖动,效果更明显——表情花朵等小图标在手机图片上方飞动的视差感觉。目前,Ch rom e以及FireFox等浏览器(不包括IE11在内的浏览器)都是有效果。

二、CSS实现的原理

原理说透了很 简单 ,下面几个关键CSS声明起的作用( 红色 高亮部分):

.cont ai ner {      /* 滚动容器 */      @H_ 304 _24@ PE rspective: 1px;       padding: 0; h ei ght: calc(100vh - 300px); overflow: auto; } .box {      /* 视差元素的父级需要3D视角 */      height: 1280px;      transform -s tyle:  PR eserve-3d;      pos IT ion: relative; } .background {      /* 滚动比较慢的背景元素 */      position: absolute; left: 50%;     transform: translate3D(-50%, -120px,  -1px )  scale(2) ; }

大家可以注意上面红色高亮代码出现了一个 1px (来自 perspective ), 一个 -1px (来自 transform )以及 scale(2) 中的 2 . 这几个数字之间有什么关系呢?

我们先看下面这个3D视角示意图(来自这里):

当我们在屏幕前面 1 个单位的地方,看屏幕后面 1 个单位的元素,肉眼所见的画面大小只有实际的 1/2 ,即所谓的近大远小。此时 scale(2) 让内容放大到 原来 2倍,正好在平面上看上去好像是原来大小。

虽然肉眼所见体积似乎是 1:1 ,但是,滚动时候的位移变化还是 1:2 , 应该 很好理解。举个极端的例子,我们坐在 电 瓶车上看天上的月亮,虽然车子在40码的速度奔啊奔,但是,好像月亮的位置没有移动,一直就在头顶。网页中的3D就是模拟真实世界的3D效果,因此,也会有这种视差体验。

或者 这么讲吧,CSS3 3D天然视差效果,滚动,只是视差体现的一个触发条件。

于是,亲爱的 同学 。如果你想实现3层视差滚动怎么办?很简单,来个 transform: translateZ(-2px) 试试~

三、结语

据我测试,直接 body 或 ht ML 滚动似乎难以实现视差滚动效果, 不过 天色已晚,我没深究,有兴趣的小伙伴可以研究分享下。

OK, 就像绚烂惊奇的魔 术 ,解密之后,会发现不过尔尔。不知你成功解密了CSS视差滚动的秘密了没?

感谢阅读,欢迎交流!

(本篇完)

觉得 可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-小tip: 纯CSS实现视差滚动效果 全部内容,希望文章能够帮你解决 html5教程-小tip: 纯CSS实现视差滚动效果 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-小tip: 纯CSS实现视差滚动效果的详细内容...

  阅读:53次