国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JS獲取動態添加元素的方法詳解

2024-05-06 16:53:53
字體:
來源:轉載
供稿:網友

本文實例講述了JS獲取動態添加元素的方法。分享給大家供大家參考,具體如下:

在頁面的渲染中,我們經常用遇到動態添加的DOM元素,那么在獲取這些元素的時候或則為這些DOM元素的時候,我們有下面三種處理方法:

  • 1.  在模板引擎里面添加行內事件
  • 2.  利用事件的委托獲取(常用)
  • 3.  在ajax的監聽響應完成函數后面獲取

一 在模板引擎里面添加行內事件

添加行內事件就是在標簽里面添加事件,這樣就可以直接獲取到動態添加的元素.

<!-- 1.準備一個模板 -->  <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>
  //事件函數,書寫在單獨的JS文件中  //帶有參數,參數是模板傳遞過來的  function updateUser (id,isDelete){      //doSomething.........  }

上面使用的模板是art-template,在模板里面我們給button標簽注冊了點擊事件onclick,但是事件函數卻是一個帶參數的函數.當點擊這個按鈕的時候,就會觸發點擊事件,進而調用updateUser()函數.

二. 利用事件的委托獲取(常用)

事件的委托可以為動態添加的元素綁定事件.

//同樣以上面的代碼為例,tr最后是添加到table中,那么將點擊事件委托給table$('table').on('click','tr #btn-status',function(){    //doSomething........})

上面的代碼意思是,將點擊事件綁定給table元素,但是我們點擊的是table里面的button按鈕,此時事件的冒泡起作用,向外冒泡遇到父元素table也有點擊事件,那么就會去執行這個事件.

三 在ajax的監聽響應完成函數后面獲取

當我們把模板渲染出來的時候,此時頁面上已經是最新的動態元素了,DOM也已經重繪完成,此時再去獲取動態元素.

$.ajax({    url : 'text.php',    dataType : 'json',    success : function(obj){        //渲染動態元素到頁面上        var trHTML = template('tpl-table',obj);        $('table').append(trHTML);        //獲取動態元素注冊點擊事件        $('tr #btn-status').on('click',function(){            //doSomething........        });    }})

四 總結:

第一種方法要注意事件函數必須是全局函數;第二種最常用,但是三者的共同點都是當頁面已經渲染完畢后才能獲取到動態元素.

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临澧县| 海南省| 通城县| 浦江县| 广州市| 视频| 绩溪县| 桓台县| 苗栗市| 济源市| 磐石市| 南澳县| 开封县| 健康| 筠连县| 绥宁县| 安化县| 涞水县| 景谷| 城固县| 黄浦区| 万荣县| 周至县| 平和县| 三原县| 黄大仙区| 确山县| 屏东市| 铁岭市| 商河县| 永新县| 宜宾市| 保亭| 兰溪市| 凤凰县| 洪湖市| 蕉岭县| 抚顺县| 通江县| 临洮县| 沁源县|