强制 DOM 在 Chrome/Mac 上重绘/刷新
2022-08-30 00:38:47
每隔一段时间,Chrome就会错误地呈现完全有效的HTML / CSS或根本不呈现。通过DOM检查器进行挖掘通常足以使其意识到其方式的错误并正确重绘,因此可以证明标记是好的。在我正在处理的项目中,这种情况经常发生(并且可以预测),以至于我已经将代码放在适当的位置,以便在某些情况下强制重绘。
这适用于大多数浏览器/操作系统组合:
el.style.cssText += ';-webkit-transform:rotateZ(0deg)'
el.offsetHeight
el.style.cssText += ';-webkit-transform:none'
例如,调整一些未使用的CSS属性,然后询问一些强制重绘的信息,然后取消该属性。不幸的是,Chrome for mac背后的聪明团队似乎已经找到了一种方法来获得这种偏移量,而无需重绘。从而杀死一个本来有用的黑客。
到目前为止,我想出的在Chrome / Mac上获得相同效果的最好的方法是这个丑陋:
$(el).css("border", "solid 1px transparent");
setTimeout(function()
{
$(el).css("border", "solid 0px transparent");
}, 1000);
就像在,实际上迫使元素跳跃一点,然后冷却一秒钟并将其跳回去。更糟糕的是,如果您将超时时间降至500ms以下(到不太明显的位置),它通常不会产生预期的效果,因为浏览器在返回其原始状态之前不会重新绘制。
有没有人关心提供在Chrome / Mac上运行的此重绘/刷新黑客的更好版本(最好基于上面的第一个示例)?