首頁 >web前端 >js教程 >如何解決jquery on 不生效問題

如何解決jquery on 不生效問題

藏色散人
藏色散人原創
2020-11-26 11:25:213815瀏覽

jquery on不生效的解決方案:先開啟對應的程式碼檔案;然後透過正確的方法「$('body').on('click', '#test .evt', function() {alert($(this).text())});」使用on即可。

如何解決jquery on 不生效問題

本教學操作環境:Windows7系統、jquery1.10.0版,此方法適用於所有品牌電腦。

推薦:《jquery教學

jquery的on()綁定無效的方式

on前面的元素也必須在頁面載入的時候就存在於dom裡面。動態的元素或樣式等,可以放在on的第二個參數裡面

jQuery on()方法是官方推薦的綁定事件的一個方法。使用 on() 方法可以給將來動態建立的動態元素綁定指定的事件,例如append等。

<div id="test">
<div class="evt">evt1</div>
</div>

錯誤的用法,下面方法只為第一個class 為evt 的div 綁定了click事件,使用append動態建立的div則沒有綁定

<script>
// 先绑定事件再添加div
$(&#39;#test .evt&#39;).on(&#39;click&#39;, function() {alert($(this).text())});
$(&#39;#test&#39;).append(&#39;<div class="evt">evt2</div>&#39;);
</script>

正確的用法如下:

<script>
$(&#39;body&#39;).on(&#39;click&#39;, &#39;#test .evt&#39;, function() {alert($(this).text())});
$(&#39;#test&#39;).append(&#39;<div class="evt">evt2</div>&#39;);
</script>

checkbox單選設定  如果ef32da46e2c234ae705f71c3bfd6d43d是動態新增的則可以這樣

$("#grid").on("click","input[name=ck]",function(){
$("input[name=ck]").not(this).prop("checked",false);
});

  註:$(selector).on (event,childSelector,data,function,map)

以上是如何解決jquery on 不生效問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:jquery是啥意思下一篇:jquery是啥意思