jquery是一款經典的 javascript 庫,其強大的選擇器和遍歷功能深受廣大 web 開發者的喜愛。然而,使用 jquery 遍歷動態添加的 input 等元素時,可能會遇到一些問題。
首先,我們需要清楚一點:動態添加的 input 無法通過 jquery 的一些常規選擇器來直接獲取。因為它們并不是在頁面加載時即存在的元素,jquery 并不認為它們存在于 DOM 中。那么,我們該如何用 jquery 遍歷這些元素呢?
一種可行的方案是使用 on() 方法和事件委托機制。對于動態添加的 input,我們可以通過事件委托機制來監聽它們的事件,進而獲取到它們的值,如下所示:
$(document).on("input", "input.dynamic", function() { var value = $(this).val(); console.log(value); });
上述代碼中,我們監聽整個文檔的 input 事件,并通過選擇器指定需要監聽的元素為所有類名為 dynamic 的 input。當用戶輸入時,我們可以通過 $(this) 獲取到當前操作的 input,進而獲取到其值并打印到控制臺中。
除了 on() 方法外,我們還可以使用 find() 方法進行遍歷。find() 方法會沿著 DOM 樹查找元素,可以找到動態添加的 input。代碼如下:
// 假設動態添加的 input 其父元素 ID 為 container $("#container").find("input").each(function() { var value = $(this).val(); console.log(value); });
上述代碼中,我們獲取到父元素 container 并使用 find() 方法查找其下所有的 input 元素。使用 each() 方法循環遍歷找到的 input,并獲取到其值并打印到控制臺中。
相信通過上述兩種方式,開發者們已經可以輕松地遍歷動態添加的 input 元素了。