ホームページ > ウェブフロントエンド > jsチュートリアル > jQuery が重複 ID を持つ最初の要素のみを選択するのはなぜですか?

jQuery が重複 ID を持つ最初の要素のみを選択するのはなぜですか?

Linda Hamilton
リリース: 2024-12-07 17:53:13
オリジナル
352 人が閲覧しました

Why Does jQuery Only Select the First Element with a Duplicate ID?

無効な HTML: 同じ ID を持つ複数の要素

問題の説明:

HTML 構造を考慮すると、同じ ID「xyz」を持つボタンが 3 つあります。ただし、jQuery ID セレクター $("#xyz") を使用して onClick イベントを処理する場合、最初のボタンのみが応答します。他のボタンは無視されます。

分析:

jQuery ID セレクターは、ドキュメント内で一致する ID を持つ最初の要素を選択するように設計されています。ただし、W3C 仕様によれば、ID 値はドキュメント内で一意である必要があります。同じ ID を持つ複数の要素があると、無効な HTML とみなされます。

jQuery API ドキュメントで説明されているように、複数の要素が同じ ID を持つ場合、jQuery セレクターは最初に一致した要素のみを選択します。この動作に依存することはお勧めできません。ID の一意性を確保するために HTML を修正する必要があります。

解決策:

この問題を解決するには、id 属性を次のように置き換えます。ボタンのクラス属性。これにより、HTML 検証ルールに違反することなく、ボタンに異なる値を設定できるようになります。

改訂された HTML:

<button type="button" class="btn btn-primary xyz" value="1">XYZ1</button>
<button type="button" class="btn btn-primary xyz" value="2">XYZ2</button>
<button type="button" class="btn btn-primary xyz" value="3">XYZ3</button>
ログイン後にコピー

更新された jQuery スクリプト:

xyz クラスを使用してすべてのボタンのクリック イベントを処理するには、次のコマンドを使用します。 jQuery コード:

$(".xyz").click(function(){
    // Get the value of the button that was clicked
    var xyz = this.value;

    // Display the value in an alert box
    alert(xyz);
});
ログイン後にコピー

この更新されたコードは、3 つのボタンすべての onClick イベントを適切に処理し、それぞれの値をアラート ボックスに表示します。

以上がjQuery が重複 ID を持つ最初の要素のみを選択するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート