- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在开发一个视差插件,以帮助创建垂直滚动网站之一,其中某些元素会创建视差效果。
大多数插件使用巨大的 DIV 标签并滚动背景。就我而言,这是行不通的,因为客户希望动画角色 Sprite 和各种其他元素具有视差 - 就像内容一样。因此,我需要移动元素本身,而不是移动背景。我还没有找到可以做到这一点的插件。
我的插件运行得非常好,除了一个异常(exception)。随着紧张或沉重的滚动,元素会在页面上爬行 - 而不是在垂直开始的地方结束。这是一个示例(请原谅可怕的样式,这是一个粗糙的模型):http://www.nebulus.org/parallax-test
哦,正在进行的插件在这里:http://www.nebulus.org/parallax-test/js/libs/jquery.scrollParallax.js
如果您快速向上/向下滚动,您会注意到页面顶部的 Sprite 最终距离它们开始的位置很远。有人知道如何让他们表现得更好吗?非常感谢您的帮助 - 我确实计划在完成后发布该插件(轻推,眨眼)。
最佳答案
对于位置的微小变化 (containerScrollY1-containerScrollY2) = 1 或 -1,您会遇到舍入问题
newY = myPosY + (containerScrollY1-containerScrollY2)*params.inertiaY;
$base.css('top',newY+'px');
如果inertia = 0.25
然后向下滚动一个像素,then new = old - 0.25
到哪些楼层old - 1
如果向上滚动一个像素,则 new = old + 0.25
到哪些楼层old
因此,对于单个像素的任何滚动(我记录了很多尝试您的代码的情况),向下滚动时对象会向上移动一个,而向上滚动时则根本不会移动。
对于位置的大变化(您谈到的快速滚动),问题源于仅移动可见的对象。如果删除 isVisible
内部状况handleScrolling
,快速滚动问题就消失了(只要每次滚动足够大,以避免上面的舍入问题)。例如,滚动 100 像素会导致离屏 20 像素的对象在未记录的跳跃中移动 80 像素(即,其 myPosY
不同步 80 像素)。
为了解决这两个问题,我会将对象的原始位置存储为参数,然后始终根据该绝对位置计算其视差位置。如newY = params.origY - $(params.container).scrollTop()*inertiaY
这对我有用。祝你好运!
此外,http://johnpolacek.github.com/scrollorama/非常好,如果你还没有尝试过的话,它还有视差。但不知道它是否适合您的具体情况。
关于jQuery Parallax - 元素没有在这里结束,而是开始,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8247731/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!