JS獲取動態(tài)添加元素的方法詳解
本文實例講述了JS獲取動態(tài)添加元素的方法。分享給大家供大家參考,具體如下:
在頁面的渲染中,我們經(jīng)常用遇到動態(tài)添加的DOM元素,那么在獲取這些元素的時候或則為這些DOM元素的時候,我們有下面三種處理方法:
- 1. 在模板引擎里面添加行內(nèi)事件
- 2. 利用事件的委托獲取(常用)
- 3. 在ajax的監(jiān)聽響應(yīng)完成函數(shù)后面獲取
一 在模板引擎里面添加行內(nèi)事件
添加行內(nèi)事件就是在標(biāo)簽里面添加事件,這樣就可以直接獲取到動態(tài)添加的元素.
<!-- 1.準(zhǔn)備一個模板 --> <script id="tpl-table" type="text/html"> {{ each rows value key }} <tr> <td> <button type="button" onclick="updateUser({{ value.id }} {{@ ','}} {{value.isDelete}})" id="btn-status" >按鈕</button> </td> </tr> {{ /each }} </script>
//事件函數(shù),書寫在單獨的JS文件中 //帶有參數(shù),參數(shù)是模板傳遞過來的 function updateUser (id,isDelete){ //doSomething......... }
上面使用的模板是art-template,在模板里面我們給button標(biāo)簽注冊了點擊事件onclick,但是事件函數(shù)卻是一個帶參數(shù)的函數(shù).當(dāng)點擊這個按鈕的時候,就會觸發(fā)點擊事件,進而調(diào)用updateUser()
函數(shù).
二. 利用事件的委托獲取(常用)
事件的委托可以為動態(tài)添加的元素綁定事件.
//同樣以上面的代碼為例,tr最后是添加到table中,那么將點擊事件委托給table $('table').on('click','tr #btn-status',function(){ //doSomething........ })
上面的代碼意思是,將點擊事件綁定給table元素,但是我們點擊的是table里面的button按鈕,此時事件的冒泡起作用,向外冒泡遇到父元素table也有點擊事件,那么就會去執(zhí)行這個事件.
三 在ajax的監(jiān)聽響應(yīng)完成函數(shù)后面獲取
當(dāng)我們把模板渲染出來的時候,此時頁面上已經(jīng)是最新的動態(tài)元素了,DOM也已經(jīng)重繪完成,此時再去獲取動態(tài)元素.
$.ajax({ url : 'text.php', dataType : 'json', success : function(obj){ //渲染動態(tài)元素到頁面上 var trHTML = template('tpl-table',obj); $('table').append(trHTML); //獲取動態(tài)元素注冊點擊事件 $('tr #btn-status').on('click',function(){ //doSomething........ }); } })
四 總結(jié):
第一種方法要注意事件函數(shù)必須是全局函數(shù);第二種最常用,但是三者的共同點都是當(dāng)頁面已經(jīng)渲染完畢后才能獲取到動態(tài)元素.
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript頁面元素操作技巧總結(jié)》、《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
JavaScript中的數(shù)組遍歷forEach()與map()方法以及兼容寫法介紹
下面小編就為大家?guī)硪黄狫avaScript中的數(shù)組遍歷forEach()與map()方法以及兼容寫法介紹。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05JavaScript 隱式類型轉(zhuǎn)換規(guī)則詳解
這篇文章主要為大家介紹了JavaScript 隱式類型轉(zhuǎn)換規(guī)則詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2023-05-05JavaScript尾遞歸的實現(xiàn)及應(yīng)用場景
本文主要介紹了JavaScript尾遞歸的實現(xiàn)及應(yīng)用場景,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05JavaScript??际謱戭}之柯里化與數(shù)組扁平化的實現(xiàn)
這篇文章主要為大家詳細介紹了JavaScript常考手寫題中柯里化與數(shù)組扁平化、數(shù)組去重的實現(xiàn),文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12JS實現(xiàn)遠程控制的基本原理和實現(xiàn)方法
遠程控制是指通過網(wǎng)絡(luò)等遠距離通訊手段控制另一設(shè)備的操作行為,在現(xiàn)實生活中,隨著物聯(lián)網(wǎng)技術(shù)的不斷發(fā)展,遠程控制技術(shù)越來越重要,本文將詳細介紹?JS?實現(xiàn)遠程控制的基本原理、開發(fā)流程和實現(xiàn)方法,需要的朋友可以參考下2023-06-06