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

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

Linda Hamilton
Linda Hamilton原创
2024-11-29 07:26:10367浏览

How to Force a DOM Redraw in Chrome for Mac?

如何在 Chrome for Mac 上强制重绘 DOM

在 Web 开发中,有时需要强制浏览器重绘或刷新 DOM DOM(文档对象模型)。虽然有多种方法适用于大多数浏览器,但 Mac 版 Chrome 提出了独特的挑战。

修改未使用的 CSS 属性、查询元素尺寸,然后恢复更改的标准技术不再适用Mac 版 Chrome。此行为是由于在检索 offsetHeight 属性时防止重绘的优化所致。

要克服此限制,可以采用一种更具侵入性的方法:

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

虽然此方法可确保重绘时,它还会导致元素位置发生明显的跳跃,这可能是不受欢迎的。保证重绘的更微妙的方法是:

$('#parentOfElementToBeRedrawn').hide().show(0);

这会隐藏然后立即显示父元素,强制回流。或者,在纯 JavaScript 中:

document.getElementById('parentOfElementToBeRedrawn').style.display = 'none';
document.getElementById('parentOfElementToBeRedrawn').style.display = 'block';

为了对重绘时间进行更细粒度的控制,可以定义自定义函数:

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn