ホームページ >ウェブフロントエンド >CSSチュートリアル >Chrome for Mac で DOM の再描画/更新を強制する方法

Chrome for Mac で DOM の再描画/更新を強制する方法

Susan Sarandon
Susan Sarandonオリジナル
2024-12-23 10:57:35996ブラウズ

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'

ただし、 Chrome for Mac は、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
}

このアプローチは再描画を保証し、border メソッドよりも効率的です。

以上がChrome for Mac で DOM の再描画/更新を強制する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。