首頁 >web前端 >css教學 >如何在 Mac 版 Chrome 強制 DOM 重繪/刷新?

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

Susan Sarandon
Susan Sarandon原創
2024-12-23 10:57:351086瀏覽

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn