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

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

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-29 07:26:10370ブラウズ

How to Force a DOM Redraw in Chrome for Mac?

Chrome for Mac で DOM 再描画を強制する方法

Web 開発では、ブラウザーに強制的に再描画または更新をさせる必要がある場合があります。 DOM (ドキュメント オブジェクト モデル)。ほとんどのブラウザで機能するさまざまなアプローチがありますが、Chrome for Mac には独特の課題があります。

未使用の 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
}

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

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