ホームページ >ウェブフロントエンド >CSSチュートリアル >追加された要素で CSS トランジションをトリガーするにはどうすればよいですか?

追加された要素で CSS トランジションをトリガーするにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-04 04:20:29657ブラウズ

How to Trigger CSS Transitions on Appended Elements?

追加された要素で CSS トランジションをトリガーする

即時 CSS アニメーションが無視されるのはなぜですか?

要素が DOM に追加される場合、ブラウザはパフォーマンスを最適化するためにバッチリフローを行うことがよくあります。ただし、これにより即時の CSS トランジションが無視され、トランジションの終了状態が即座にレンダリングされる可能性があります。

これらのメソッドはどのように機能するのでしょうか?

  • setTimeout: 新しい JavaScript ラウンドへのクラスの追加を遅らせ、遷移中にレンダリング エンジンが補間する 2 つの異なるスタイル値が存在するようにします。
  • offsetWidth: リフローの原因となるプロパティにアクセスすることでリフローを強制し、初期スタイル値の計算をトリガーします。
  • focus: 同期リフローをトリガーして、トランジションをすぐに開始できるようにします。

他の方法はありますか?

追加された要素でトランジションをトリガーする他の方法は次のとおりです:

  • requestAnimationFrame:最初の追加ラウンドから分離して、次のブラウザ フレームでクラスの追加をスケジュールします。
  • MutationObserver: DOM の変更を監視し、それに応じて遷移をトリガーします。

推奨ソリューション

推奨ソリューションは主観的なものですが、多くの開発者は、同期リフローを強制し、遷移の実行を保証するため、offsetWidth へのアクセスを好みます。この方法は主要なブラウザでもサポートされています。

以上が追加された要素で CSS トランジションをトリガーするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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