亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

DOM 事件流詳解

2019-11-20 13:21:33
字體:
來源:轉載
供稿:網友

1.冒泡型事件

瀏覽器的事件模型分兩種:捕獲型事件和冒泡型事件。由于ie不支持捕獲型事件,所以以下主要以冒泡型事件作為講解。
(dubbed bubbling)冒泡型指事件安裝最特定的事件到最不特定的事件逐一觸發。

復制代碼 代碼如下:

    <body onclick="add('body<br>')">
        <div onclick="add('div<br>')">
            <ponclick="add('p<br>')"> click me</p>
        </div>
    </body>
    <div id="display">

    </div>
    <script type="text/javascript">
        function add(sText) {
            var ulo = document.getElementById("display");
            ulo.innerHTML += sText;
        }
    </script>

以上三個函數都添加了onclick函數,單機p元素后三個函數都觸發,先執行了p元素,再執行了div,最后執行了body

這這里順便提醒下捕獲型事件,它的順序正好和冒泡型事件相反。

2.事件監聽

一個事件都需要函數來響應,這類函數通常稱為事件處理函數(enent  handler),從另外一個角度看,這些函數都在實時監聽著是否有事件發生,通常稱為事件監聽函數(enevt listener),事件監聽函數對于不同的瀏覽器區別較大。

i.通用監聽方法,比如使用onclick方法,幾乎每個標簽都支持此方法。而且瀏覽器兼容性都很高
考慮到行為,事件分離。
一般使用使用以下方式進行監聽

復制代碼 代碼如下:

<body>
<div id="me">click</div>
<script type="text/javascript">
var opp = document.getElementById("me"); //找到事件
opp.onclick = function(){                   //設置事件函數
    alert("我被點擊了!")
}
</script>
</body>

以上介紹的兩者方法都十分便捷,在制作處理一些小功能時都被光大開發者所喜愛。但對于同一個事件。他們都只能添加一個函數,列如對于p標記的onclick函數,利用這兩種方法都只能有一個函數,因此,ie有自己的解決辦法,同事,標準的dom則規定了另外一種方法。

ii.IE中的監聽方法
早ie瀏覽器中,每個元素都有兩個方法來處理時間的監聽。
分別是attachEvent()和detachEnevt()。
從它們的函數名稱就能看出來,attachEnevt()是用來給某個元素添加事件處理的函數,而detachEvent()則是用來刪除元素上的監聽函數。它們的語法如下:

[object].attachEvent("enevt_handler","fnHandler");
[object].detachEvent("enevt_handler","fnHandler");
其中enevt_handler代表常用的onclick , onload, onmouseover等
fnHandler是監聽函數的名稱。
上一節事件中可以使用attachEvent()方法替代添加監聽函數,當單擊了一下,可以使用detachEvent()刪除監聽函數,使其下次單擊后再不執行。

復制代碼 代碼如下:

<script type="text/javascript">
            function fnclick() {
                alert("我被點擊了!");
                oP.detachEvent("onclick","fnclick");
            }
            var oP;
            window.onload = function() {
                oP = document.getElementById("oop"); //找到對象
                oP.attachEvent("onclick","fnclick"); //添加監聽函數       

            }
        </script>
        <div>
            <p id="oop">

            </p>
        </div>

iii.添加多個監聽事件(ie)

復制代碼 代碼如下:

<script language="javascript">
function fnClick1(){
    alert("我被fnClick1點擊了");
}
function fnClick2(){
    alert("我被fnClick2點擊了");
    //oP.detachEvent("onclick",fnClick1);        //刪除監聽函數1
}
var oP;
window.onload = function(){
    oP = document.getElementById("myP");    //找到對象
    oP.attachEvent("onclick",fnClick1);        //添加監聽函數1
    oP.attachEvent("onclick",fnClick2);        //添加監聽函數2
}
</script>
</head>

<body>
    <div>
        <p id="myP">Click Me</p>
    </div>

 3.標準DOM事件監聽

與ie的兩個方法對于,標準DOM也使用兩個方法分別添加和刪除監聽函數。即addEventListener(),和removeEventListener()

與ie不同,這兩個函數接受3個參數,即事件的名稱,要分配的函數名和是用于冒泡階段還是捕獲階段。捕獲階段的參數為true,冒泡階段參數為false.語法如下:

復制代碼 代碼如下:

[object].addEventListener("event_name",fnHandler,bCapture);
[object].removeEventListener("event_name",fnHandler,bCapture);

這兩個函數的使用方法和ie基本類似,只不過要注意,event_name的名稱是“click”,“mouseover”等,而不是Ie中的“onclick”,“onmouseover”。

另外第三個參數bCapture通常設置為false,冒泡階段。

標準dom的事件監聽方法:

復制代碼 代碼如下:

    <script language="javascript">
            function fnClick1() {
                alert("我被點擊了1");
                oP.removeEventListener("click", fnClick1, false);
            }

            function fnClick2() {
                alert("我被點擊了2");
            }

            window.onload = function() {
                oP = document.getElementById("myP");
                oP.addEventListener("click", fnClick1, false);
                oP.addEventListener("click", fnClick2, false);
            }
        </script>
        <div>
            <p id="myP">Click Me</p>
        </div>

具體的執行順序大家可測試。

以上就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久综合伊人77777尤物| 国产精品久久久久影院日本| 欧美激情喷水视频| 亚洲丝袜在线视频| 久久精品视频va| 亚洲人成免费电影| 色777狠狠综合秋免鲁丝| 精品久久久久久久久久久| 九九热这里只有在线精品视| 亚洲最大的成人网| 久久久噜噜噜久久久| 久久视频在线视频| 久热爱精品视频线路一| 国产精品一区二区性色av| 亚洲欧美制服另类日韩| 亚洲女人天堂成人av在线| 日韩亚洲第一页| 国产精品91久久久| 69久久夜色精品国产69| 日韩专区在线播放| 国产精品一区二区电影| 欧美主播福利视频| 孩xxxx性bbbb欧美| 亚洲国产欧美自拍| 久久国产精品首页| 伊人亚洲福利一区二区三区| 2020久久国产精品| 国产精品黄页免费高清在线观看| 亚洲老头老太hd| 国产精品美女无圣光视频| 亚洲人av在线影院| 日本成人激情视频| 亚洲欧美另类自拍| 日本久久久a级免费| 久久久av网站| 国产成人精品一区二区| 欧美国产视频一区二区| 欧美高清视频免费观看| 欧美精品久久久久久久免费观看| 国产精品丝袜久久久久久高清| 欧美日韩在线免费| 精品自拍视频在线观看| 国产欧美日韩中文字幕| 国产成人91久久精品| 国产va免费精品高清在线| 亚洲国模精品一区| 欧美一级在线亚洲天堂| 久久91精品国产91久久久| 欧美人成在线视频| 国产做受高潮69| 91人人爽人人爽人人精88v| 欧美一级电影久久| 日本一区二三区好的精华液| 日韩免费在线视频| 欧美性视频在线| 精品一区二区三区四区在线| 日韩高清中文字幕| 精品高清一区二区三区| 国外视频精品毛片| 在线观看日韩欧美| 国产精品影院在线观看| 久久久久久久久爱| 中文字幕亚洲二区| 精品福利在线观看| 亚洲自拍中文字幕| 欧美视频中文字幕在线| 日韩高清电影免费观看完整版| 国产成人久久久精品一区| 亚洲专区中文字幕| 精品女同一区二区三区在线播放| 中文字幕日韩高清| 91欧美精品成人综合在线观看| 国产精品午夜国产小视频| 热久久免费国产视频| 亚洲成人激情小说| 国产啪精品视频网站| 91久久综合亚洲鲁鲁五月天| 91夜夜揉人人捏人人添红杏| 亚洲综合小说区| 久青草国产97香蕉在线视频| 成人黄色免费看| 亚洲理论片在线观看| 中文字幕亚洲一区二区三区五十路| 国产色综合天天综合网| 欧美在线视频导航| 2021久久精品国产99国产精品| 欧美黑人xxxⅹ高潮交| 国产欧美精品一区二区三区-老狼| 久久人91精品久久久久久不卡| 日韩二区三区在线| 欧美激情三级免费| 亚洲色无码播放| 91精品久久久久久综合乱菊| 欧美在线视频播放| 国产精品一久久香蕉国产线看观看| 国产主播欧美精品| 国产成人精品视频| 久久精品国产精品| 久久天天躁狠狠躁夜夜av| 国产精品99久久久久久久久| 日韩成人黄色av| 久久精品国产91精品亚洲| 国产亚洲日本欧美韩国| 欧美性猛交xxxx富婆弯腰| 最新中文字幕亚洲| 日韩av电影在线网| 亚洲欧美国产精品专区久久| 成人性生交大片免费看视频直播| 欧美激情在线狂野欧美精品| 伊人伊成久久人综合网站| 夜色77av精品影院| 欧美色视频日本高清在线观看| 欧美黑人性猛交| 久久精品国产欧美亚洲人人爽| 亚洲成年网站在线观看| 国产精品99久久久久久久久| 欧美韩国理论所午夜片917电影| 欧美日韩国产精品一区| 国产精品久久久久久av福利| 精品久久久免费| 欧美国产一区二区三区| 亚洲黄色有码视频| 91精品国产综合久久久久久蜜臀| 欧美最猛黑人xxxx黑人猛叫黄| 成人深夜直播免费观看| 日韩av一区在线| 亚洲女成人图区| 久久免费精品日本久久中文字幕| 日韩欧美成人区| 日韩av理论片| 国产午夜精品美女视频明星a级| 国产精品欧美一区二区三区奶水| 亚洲在线观看视频| 在线精品国产欧美| 国产免费一区二区三区在线观看| 亚洲精品综合精品自拍| 热99精品里视频精品| 国产精品极品尤物在线观看| 日韩成人网免费视频| 国产精品黄色影片导航在线观看| 中文字幕欧美日韩精品| 92版电视剧仙鹤神针在线观看| 欧美电影院免费观看| 黄色精品在线看| 国自产精品手机在线观看视频| 欧美极度另类性三渗透| 中文一区二区视频| 亚洲女性裸体视频| 欧美成人激情在线| 亚洲精品永久免费| 97人人爽人人喊人人模波多| 国产成人一区二区三区小说| 亚洲成色www8888| 亚洲第一页在线| 久久久亚洲精品视频| 久久久久在线观看| 中文字幕亚洲欧美一区二区三区| www.亚洲成人| 国产精品揄拍一区二区| 成人激情视频在线播放| 97久久精品在线| 国产成人一区二区三区小说| 久久视频精品在线| 欧美性xxxxxxxxx|