首頁 > web前端 > js教程 > 主體

如何解決jquery on 不生效問題

藏色散人
發布: 2020-11-30 10:58:28
原創
3750 人瀏覽過

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單選設定  如果是動態新增的則可以這樣

$("#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中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板