jQuery on()綁定動態元素出現的問題小結_jquery
jQuery on()方法是官方推薦的綁定事件的一個方法。使用 on() 方法可以給將來動態建立的動態元素綁定指定的事件,例如append等。
之前使用 on 的時候一直是
$("").on('click','function(){ }')
之後發現有些時候一直無法綁定(例如元素動態生成時),查看文件後發現正確用法應該是
$(document).on("change","#pageSize_out",function(){ if($("#page_out").val()!=0){ $("#pageSize").val($(this).val()); list(); } })
同時,注意
As this answers receives a lot of attention, here are two supplementary advises :
1) When it's possible, try to bind the event listener to the most precise element, to avoid useless event handling.
That is, if you're adding an element of class b to an existing element of id a, then don't use $(document.body).on('click', '#a .b', function(){ but use $('#a').on('click', '.b', function(){
2) Be careful, when you add an element with an id, to ensure you're not adding it twice. Not only is it "illegal" in HTML to have two elements with the same id but it breaks a lot of things. For example a selector "#c" would retrieve only one element with this id.
on(events,[selector],[data],fn)
events:一個或多個空格分隔的事件類型和可選的命名空間,如"click"或"keydown.myPlugin" 。
selector:一個選擇器字串用於過濾器的觸發事件的選擇器元素的後代。如果選擇器為null或省略,當它到達選定的元素,事件總是觸發。
data:當一個事件被觸發時要傳遞event.data給事件處理函數。
fn:該事件被觸發時執行的函數。 false 值也可以做一個函數的簡寫,回傳false。
替換bind()
當第二個參數'selector'為null時,on()和bind()其實在用法上基本上沒有任何區別了,所以我們可以認為on()只是比bind()多了一個可選的'selector'參數,所以on()可以很方便的換掉bind()
替換live()
在1.4之前相信大家非常喜歡使用live(),因為它可以把事件綁定到當前以及以後添加的元素上面,當然在1.4之後delegate()也可以做類似的事情了。 live()的原理很簡單,它是透過document進行事件委派的,因此我們也可以使用on()透過將事件綁定到document來達到live()一樣的效果。
live()寫法
程式碼如下:
$('#list li').live('click', '#list li', function() { //function code here. });
on()寫法
程式碼如下:
$(document).on('click', '#list li', function() { //function code here. });
這裡的關鍵就是第二個參數'selector'在運作了。它是一個過濾器的作用,只有被選中元素的後代元素才會觸發事件。
替換delegate()
delegate()是1.4引入的,目的是透過祖先元素來代理委派後代元素的事件綁定問題,某種程度上和live()優點相似。只不過live()是透過document元素委派,而delegate則可以是任意的祖先節點。使用on()實作代理的寫法和delegate()基本上一致。
delegate()的寫法
程式碼如下:
$('#list').delegate('li', 'click', function() { //function code here. });
on()寫法
程式碼如下:
$('#list').on('click', 'li', function() { //function code here. });
似乎第一個和第二個參數的順序顛倒了一下,別的基本一樣。
總結
jQuery推出on()的目的有2個,一是為了統一接口,二是為了提高性能,所以從現在開始用on()替換bind(), live(), delegate吧。尤其是不要再用live()了,因為它已經處於不建議使用清單了,隨時會被幹掉。如果只綁定一次事件,那接著用one()吧,這個沒有變化。
jquery on() 方法綁定動態元素
廢話不多說了,直接給大家貼程式碼了。
<div id="test"> <div class="evt">evt1</div> </div>
錯誤的用法,下面方法只為第一個class 為 evt 的div 綁定了click事件,使用append動態建立的div則沒有綁定
<script> // 先绑定事件再添加div $('#test .evt').on('click', function() {alert($(this).text())}); $('#test').append('<div class="evt">evt2</div>'); </script>
正確的用法如下:
<script> $('body').on('click', '#test .evt', function() {alert($(this).text())}); $('#test').append('<div class="evt">evt2</div>'); </script>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

本文說明瞭如何使用源地圖通過將其映射回原始代碼來調試JAVASCRIPT。它討論了啟用源地圖,設置斷點以及使用Chrome DevTools和WebPack之類的工具。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

本教程將介紹如何使用 Chart.js 創建餅圖、環形圖和氣泡圖。此前,我們已學習了 Chart.js 的四種圖表類型:折線圖和條形圖(教程二),以及雷達圖和極地區域圖(教程三)。 創建餅圖和環形圖 餅圖和環形圖非常適合展示某個整體被劃分為不同部分的比例。例如,可以使用餅圖展示野生動物園中雄獅、雌獅和幼獅的百分比,或不同候選人在選舉中獲得的投票百分比。 餅圖僅適用於比較單個參數或數據集。需要注意的是,餅圖無法繪製值為零的實體,因為餅圖中扇形的角度取決於數據點的數值大小。這意味著任何占比為零的實體

掌握了入門級TypeScript教程後,您應該能夠在支持TypeScript的IDE中編寫自己的代碼,並將其編譯成JavaScript。本教程將深入探討TypeScript中各種數據類型。 JavaScript擁有七種數據類型:Null、Undefined、Boolean、Number、String、Symbol(ES6引入)和Object。 TypeScript在此基礎上定義了更多類型,本教程將詳細介紹所有這些類型。 Null數據類型 與JavaScript一樣,TypeScript中的null
