中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js之dom2級事件的示例分析

發布時間:2021-08-19 10:28:02 來源:億速云 閱讀:134 作者:小新 欄目:web開發

這篇文章主要介紹js之dom2級事件的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

我們使用的DOM2事件綁定,其實是讓box通過原型鏈一直找到EventTarget這個內置類原型上的addEventListener方法實現的。

DOM0級事件綁定:只能給一個元素的某一個行為綁定一次方法,第二次綁定的會把前面的覆蓋掉。

DOM2:可以給某一個元素的同一個行為綁定多個不同的方法

box.addEventListener('click',function(e){
      console.log(1)
    },false)
    box.addEventListener('click',function(e){
      console.log(2)
    },false) // 輸出1 2

DOM2:DOM0中的行為類型,我們用DOM2一樣可以綁定,而且DOM2中還提供了一些DOM0沒有的行為類型->DOMContentLoaded:當頁面中的DOM結構(HTML結構加載完成)觸發的行為

box.addEventListener('DOMContentLoaded',function(e){
      
    },false)
window.onload = function(){}

//當頁面中的所有資源都加載完成(圖片、HTML結構、音視頻...)才會執行后面的函數;并且在一個頁面中只能用一次,后面在寫會把前面的覆蓋掉;->因為他是采用DOM0事件綁定,所以只能綁定一次
     $(document).ready(function(){})//->$(function(){})
    /*
      只要頁面中的HTML結構加載完成就會執行對應的函數;并且在同一個頁面中可以出現多次。因此這個是采用DOM2事件的綁定,綁定的行為是DOMContentLoaded
    */

DOM2級添加和移除事件細節

function fn1(e){
      console.log(this);
    }
    //添加事件
    box.addEventListener('click',fn1,false);
    //移除事件
    box.removeEventListener('click',fn1,false);

注意:移除的時候需要保證三個參數:行為、方法、哪個階段發生的   三個參數必須一致 ->DOM2在綁定的時候,我們一般都給他綁定的是實名函數

只能給某個元素的同一個行為綁定多個“不同”的方法(如果方法相同了,只能留一個)

當行為觸發,會按照綁定的先后順序依次把綁定的方法執行;執行的this是當前被綁定事件的元素本身

function fn1(){
      console.log(1);
    }
    //添加事件
    box.addEventListener('click',fn1,false);
    box.addEventListener('click',fn1,false);//只輸出一個1

上面涉及一個概念:事件池(用來存儲當前元素行為綁定的方法的,瀏覽器自帶的機制) 如下圖所示

js之dom2級事件的示例分析

 但是在IE6-8瀏覽器中,不支持addEventListener,如果想實現DOM2事件綁定只能用attachEvent/detachEvent

它只有兩個參數,不能像addEventListener那樣控制在哪個階段發生,默認只能在冒泡階段發生,同時行為需要添加on(和DOM0特別的類似)

box.attachEvent('onclick',fn1)

注意:和標準瀏覽器的事件池機制對比:

1、順序問題:執行的時候順序是混亂的,標準瀏覽器是按照綁定順序依次執行的

2、重復問題:ie6-8可以給同一個元素的同一個行為綁定多個相同的方法

3、this問題:ie6-8中當方法執行的時候,方法中的this不是當前的元素box而是window

以上是“js之dom2級事件的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

普宁市| 比如县| 仪征市| 开远市| 东丽区| 灵山县| 景东| 承德县| 宝应县| 鞍山市| 高密市| 潮州市| 卓资县| 剑河县| 武宣县| 贵溪市| 富源县| 通州区| 上犹县| 襄樊市| 平罗县| 绵竹市| 阿尔山市| 太仆寺旗| 宁阳县| 临海市| 南召县| 湛江市| 开平市| 新丰县| 武山县| 垣曲县| 循化| 滨州市| 抚顺市| 邢台市| 富平县| 电白县| 辽宁省| 茶陵县| 南投市|