首页 > web前端 > css教程 > 如何在 Mac 版 Chrome 中强制 DOM 重绘/刷新?

如何在 Mac 版 Chrome 中强制 DOM 重绘/刷新?

Susan Sarandon
发布: 2024-12-23 10:57:35
原创
993 人浏览过

How to Force a DOM Redraw/Refresh in Chrome for Mac?

在 Chrome for Mac 中强制 DOM 重绘/刷新

当 Chrome for Mac 遇到有效的 HTML/CSS 时,有时会错误地渲染元素,或者一点也不。虽然在浏览器控制台中检查 DOM 通常会触发重绘,但需要更自动化的解决方案。

以下 JS 片段在大多数浏览器和操作系统中都有效:

el.style.cssText += ';-webkit-transform:rotateZ(0deg)'
el.offsetHeight
el.style.cssText += ';-webkit-transform:none'
登录后复制

但是, Mac 版 Chrome 绕过 offsetHeight 触发的重绘。解决方法是使用 setTimeout 临时更改元素的边框,强制重绘:

$(el).css("border", "solid 1px transparent");
setTimeout(function()
{
    $(el).css("border", "solid 0px transparent");
}, 1000);
登录后复制

这种方法很麻烦且引人注目。在 Chrome for Mac 上强制重绘的更有效方法是在元素中插入一个空文本节点:

var forceRedraw = function(element){

    if (!element) { return; }

    var n = document.createTextNode(' ');
    var disp = element.style.display;  // don't worry about previous display style

    element.appendChild(n);
    element.style.display = 'none';

    setTimeout(function(){
        element.style.display = disp;
        n.parentNode.removeChild(n);
    },20); // you can play with this timeout to make it as short as possible
}
登录后复制

这种方法可以保证重绘,并且比边框方法更高效。

以上是如何在 Mac 版 Chrome 中强制 DOM 重绘/刷新?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板