儘管有三個具有相同ID 的按鈕,jQuery 的#id 選擇器僅響應第一個按鈕單擊。此行為源自於基本的 HTML 規則,該規則規定文件中的每個元素必須具有唯一的 ID。
提供的 HTML 程式碼透過分配相同的 ID 違反了此規則(" xyz") 到多個按鈕。根據HTML 規範,「此屬性為元素指派名稱。此名稱在文件中必須是唯一的。」
要解決此問題,請將每個按鈕都有一個類別屬性的ID 屬性:
<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>
使用更新的HTML 結構, jQuery 程式碼應修改如下:
$(".xyz").click(function(){ alert(this.value); // No need for jQuery $(this).val() to get the value of the input. });
jQuery 的 #id 選擇器僅選擇 DOM 中具有指定 ID 的第一個元素。這是因為瀏覽器中的底層 document.getElementById 函數執行此行為。
透過遵循這些準則,您可以在 jQuery 中有效地處理具有相同功能目的的多個元素,確保所有按鈕都會按預期響應點擊。
以上是為什麼我的 jQuery ID 選擇器僅適用於第一個元素?的詳細內容。更多資訊請關注PHP中文網其他相關文章!