javascript - 请教一个关于页面视差效果的实现
问题描述
页面效果:
惊蛰
关于这个效果的模仿:
我起初是在知乎获知了一个叫 skrollr.js 的库,并且学习并应用到自己的页面,由于我的页面不像上面的是静态节点,文章和图片都是请求得到,并且是分步请求依赖于 img 的 onload 事件来渲染一套(文章+背景图)的模板,并 append 到页面中。刚开始的实现是把背景图全部用 fixed 定位层叠到屏幕,利用 skrollr 的根据参照物做出 css 属性状态变化来达到效果。但实际上哪怕不写效果,只要一个 skrollr.js 的初始化函数,在安卓机上就卡得不行。 skrollr.js 作者也有指出,如下图:
后来又仔细观察了下楼上惊蛰页面的效果,发现:
容器内的每个父块都是 absolute 定位,并且都是 left:0 top: 0 right: 0 bottom: 0
容器采用了类似kinetic库利用 touch 事件使用 translate 模拟滚动。。。 效果 demo: demo
疑问:
他是如何达到视差效果,虽然看到有 z-index 属性
他的 translate 基本上是移除一屏的高度,然后后面的页面就上来了。。。 这种如何做到了,求具体解释
问题解答
回答1:全部绝对定位,右边的滚动条是模拟的。在同样的z-index高度下,后面的元素会自动的覆盖前面的元素。
所以只要把根据滚动状态来把后面的translate改变就行了,你可以理解成一个卡片覆盖另一个卡片。
简单来说,最开始滚动时把第二屏的元素往上移动,知道超过一屏则开始第二屏,以此类推。
后面就是一些背景图放大缩小之类的效果了。
相关文章:
1. javascript - jQuery中live事件在移动微信端下没有效果;代码如下2. javascript - 请问一下react-native 布局的时候,尺寸的大小是如何确定的呢?3. javascript - 小白求解:mac 下如何设置nodejs express的 NODE_NEV 环境变量4. javascript - avalon.js ms-on 事件绑定无效 ?5. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路6. mysql5.7 json查询支持7. Python如何考虑代码注入安全?8. 找一个权威、实战的微信扫码授权登录网站的开发教程或者文章9. javascript - js 修改表格元素的,可以用DOM操作实现吗?10. javascript - 实参和形参有哪些通俗的命名吗?尤其形参