ホームページ >ウェブフロントエンド >CSSチュートリアル >CSS 属性の変更を追跡するカスタム イベントを作成するにはどうすればよいですか?

CSS 属性の変更を追跡するカスタム イベントを作成するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-03 07:27:30623ブラウズ

How to Create a Custom Event to Track CSS Attribute Changes?

CSS 属性の変更を追跡するためのカスタム イベント

問題: div または任意のオブジェクトが指定されたときにイベントをトリガーするにはどうすればよいですか? CSS 属性は変更されますか?

ディスカッション:組み込みの CSS 変更イベントはありませんが、独自の CSS 変更イベントを作成できます。 2 つの方法があります:

方法 1: DOM ポーリング

<code class="javascript">var $element = $("#elementId");
var lastHeight = $("#elementId").css('height');

function checkForChanges() {
  if ($element.css('height') != lastHeight) {
    // CSS height changed
    lastHeight = $element.css('height');
  }
  setTimeout(checkForChanges, 500);
}
checkForChanges();</code>

方法 2: 手動イベントトリガー

<code class="javascript">$('#mainContent').bind('heightChange', function() {
  // CSS height changed
});

$("#btnSample1").click(function() {
  $("#mainContent").css('height', '400px');
  $("#mainContent").trigger('heightChange');
});</code>

利点:

  • 方法 1 は自動であり、DOM の変更を常に監視します。
  • 方法 2より制御され、変更した場合にのみイベントがトリガーされます。 CSS.

Documentation:

  • bind: 指定された要素にイベント ハンドラーをアタッチします。
  • trigger: イベント ハンドラーを実行します。要素にアタッチされています。

以上がCSS 属性の変更を追跡するカスタム イベントを作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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