首頁 >web前端 >js教程 >如何在 Mac 版 Chrome 強制重繪 DOM?

如何在 Mac 版 Chrome 強制重繪 DOM?

Linda Hamilton
Linda Hamilton原創
2024-11-29 07:26:10296瀏覽

How to Force a DOM Redraw in Chrome for Mac?

如何在Chrome for Mac 上強制重繪DOM

在Web 開發中,有時需要強制瀏覽器重繪或刷新DOM DOMOM>

在Web 開發中,有時需要強制瀏覽器重繪或刷新DOM DOMOM (文檔物件模型)。雖然有多種方法適用於大多數瀏覽器,但 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