- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
可以看到一个活生生的例子here .
红色方 block (显示)直接位于绿色方 block (隐藏为溢出)上方。单击正方形,两个彩色正方形立即变为完全透明。另外,红色方 block 的高度设置为0;这会触发一个过渡,但过渡是看不见的,因为红色方 block 现在是透明的。
在再次单击正方形之前,检查 toggle
函数。查看 JavaScript,我希望红色方 block 的高度在不触发转换的情况下重置为其原始值。过渡应该被抑制,因为过渡属性在高度更改时临时设置为 none
。
现在再次点击正方形。两个彩色方 block 立即变得完全不透明,但红色方 block 在其高度从 0 过渡到原始值时向下滑动。就好像由内联样式设置的高度在元素可见之前没有被 toggle
函数删除,到那时 transition 属性也被重置了。
触发回流似乎强制应用高度的变化。 (取消注释包含要测试的 offsetParent
的行。)这种行为发生在浏览器中(至少是 Chrome 和 Safari、Firefox 和 Opera),所以我想知道它是否不是某些规范的一部分。我检查了 CSS Transitions Module没有成功。知道为什么会出现这种行为,以及为什么它在各个实现中如此一致吗?
最佳答案
这真是个奇怪的问题。我认为您的代码没有做错什么——当前的浏览器实现只是有问题。
在使用 CSS 转换之前,我遇到过这些看似显而易见的错误,如果不求助于拜占庭式的 hack,处理这些错误是一个巨大的痛苦,一旦他们正在解决的错误被修复,这些错误肯定会被打破(在这种情况下,我的 WebKit 修复)。
我真的深入研究了这个问题,但无法想出一个适用于支持过渡的三个主要布局引擎(WebKit、Gecko 和 Presto)的干净解决方案。也就是说,这就是我确实弄清楚的——希望比我聪明的人(或者只是用新的眼光看待这个问题)可以接受这个答案并将其变成真正的解决方案。
看起来(我不是浏览器工程师或不熟悉规范)transition-property
的任何当前或以前的值都将继续呈现不管是否需要。因此,即使您更改了 transition-property
的值,浏览器仍会在后台呈现高度过渡,当您将高度更改回来时,您会得到它的尾端。
虽然有一个解决方案:在 JavaScript 中创建 transition
(不要将它放在样式表中的任何位置),然后删除它(之后就没有 transition
应用于 DOM 中任何位置的 #upper
的规则),更改高度,然后重新添加它。不完美,但也不是依赖错误的黑客攻击。
http://jsfiddle.net/grantheaslip/e3quW/
upper.style.removeProperty('transition');
upper.style.removeProperty('-o-transition');
upper.style.removeProperty('-moz-transition');
upper.style.removeProperty('-webkit-transition');
upper.style.removeProperty('height');
// force a reflow
// if (upper.offsetParent) { /* empty */ }
upper.style['transition'] = 'height 1000ms';
upper.style['-o-transition'] = 'height 1000ms';
upper.style['-moz-transition'] = 'height 1000ms';
upper.style['-webkit-transition'] = 'height 1000ms';
#upper {
background-color: red;
}
任何只因为 1 毫秒超时才起作用的东西可能永远不会接近生产,但我认为这值得指出,以防它帮助人们找到这个问题的根源。
我的猜测是,WebKit 没有与 Presto 或 Gecko 相同的问题,而是包括一项优化,该优化收集在同一函数中应用的样式更改并同时应用它们。同样,纯粹是来自从未接触过 WebKit 源代码或 CSS3 规范的人的猜测。
http://jsfiddle.net/grantheaslip/DFcg9/
window.setTimeout(function() {
upper.style.removeProperty('transition-property');
upper.style.removeProperty('-o-transition-property');
upper.style.removeProperty('-moz-transition-property');
upper.style.removeProperty('-webkit-transition-property');
upper.style.removeProperty('opacity');
lower.style.removeProperty('opacity');
}, 1);
这是两种解决方案的结合。同样,由于超时 hack,这真的不应该使用。
关于css - 为什么在隐藏元素时设置属性后显示元素时会发生转换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6487715/
尝试使用集成到 QTCreator 的表单编辑器,但即使我将插件放入 QtCreator.app/Contents/MacOS/designer 也不会显示。不过,相同的 dylib 文件确实适用于独
在此代码示例中。 “this.method2();”之后会读到什么?在返回returnedValue之前会跳转到method2()吗? public int method1(int returnedV
我的项目有通过gradle配置的依赖项。我想添加以下依赖项: compile group: 'org.restlet.jse', name: 'org.restlet.ext.apispark', v
我将把我们基于 Windows 的客户管理软件移植到基于 Web 的软件。我发现 polymer 可能是一种选择。 但是,对于我们的使用,我们找不到 polymer 组件具有表格 View 、下拉菜单
我的项目文件夹 Project 中有一个文件夹,比如 ED 文件夹,当我在 Eclipse 中指定在哪里查找我写入的文件时 File file = new File("ED/text.txt"); e
这是奇怪的事情,这个有效: $('#box').css({"backgroundPosition": "0px 250px"}); 但这不起作用,它只是不改变位置: $('#box').animate
这个问题在这里已经有了答案: Why does OR 0 round numbers in Javascript? (3 个答案) 关闭 5 年前。 Mozilla JavaScript Guide
这个问题在这里已经有了答案: Is the function strcmpi in the C standard libary of ISO? (3 个答案) 关闭 8 年前。 我有一个问题,为什么
我目前使用的是共享主机方案,我不确定它使用的是哪个版本的 MySQL,但它似乎不支持 DATETIMEOFFSET 类型。 是否存在支持 DATETIMEOFFSET 的 MySQL 版本?或者有计划
研究 Seam 3,我发现 Seam Solder 允许将 @Named 注释应用于包 - 在这种情况下,该包中的所有 bean 都将自动命名,就好像它们符合条件一样@Named 他们自己。我没有看到
我知道 .append 偶尔会增加数组的容量并形成数组的新副本,但 .removeLast 会逆转这种情况并减少容量通过复制到一个新的更小的数组来改变数组? 最佳答案 否(或者至少如果是,则它是一个错
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
noexcept 函数说明符是否旨在 boost 性能,因为生成的对象中可能没有记录异常的代码,因此应尽可能将其添加到函数声明和定义中?我首先想到了可调用对象的包装器,其中 noexcept 可能会产
我正在使用 Angularjs 1.3.7,刚刚发现 Promise.all 在成功响应后不会更新 angularjs View ,而 $q.all 会。由于 Promises 包含在 native
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我正在编写一个玩具(物理)矢量库,并且遇到了 GHC 坚持认为函数应该具有 Integer 的问题。是他们的类型。我希望向量乘以向量以及标量(仅使用 * ),虽然这可以通过仅使用 Vector 来实现
PHP 的 mail() 函数发送邮件正常,但 Swiftmailer 的 Swift_MailTransport 不起作用! 这有效: mail('user@example.com', 'test
我尝试通过 php 脚本转储我的数据,但没有命令行。所以我用 this script 创建了我的 .sql 文件然后我尝试使用我的脚本: $link = mysql_connect($host, $u
使用 python 2.6.4 中的 sqlite3 标准库,以下查询在 sqlite3 命令行上运行良好: select segmentid, node_t, start, number,title
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我是一名优秀的程序员,十分优秀!