亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS傳播事件、取消事件默認(rèn)行為、阻止事件傳播詳解

 更新時(shí)間:2017年08月14日 14:15:47   作者:忄去  
這篇文章主要介紹了JS傳播事件、取消事件默認(rèn)行為、阻止事件傳播,通過事件處理程序的返回值 調(diào)用順序講解了詳細(xì)的過程,需要的朋友可以參考下

1.事件處理程序的返回值 

      通常情況下,返回值false就是告訴瀏覽器不要執(zhí)行這個(gè)事件相關(guān)的默認(rèn)操作。例如,表單提交按鈕的onclick事件處理程序能通過返回false阻止瀏覽器提交表單,再如a標(biāo)簽的onclick事件處理程序通過返回false阻止跳轉(zhuǎn)href頁面。類似地,如果用戶輸入不合適的字符,輸入域上的onkeypress事件處理程序能通過返回false來過濾鍵盤輸入。 
      事件處理程序的返回值只對(duì)通過屬性注冊(cè)的處理程序才有意義。

2.調(diào)用順序

      文檔元素或其他對(duì)象可以為指定事件類型注冊(cè)多個(gè)事件處理程序。當(dāng)適當(dāng)?shù)氖录l(fā)生時(shí),瀏覽器必須按照如下規(guī)則調(diào)用所有的事件處理程序:

通過設(shè)置對(duì)象屬性或HTML屬性注冊(cè)的處理程序一直優(yōu)先調(diào)用。
使用addEventListener()注冊(cè)的處理程序按照它們的注冊(cè)順序調(diào)用。
使用attachEvent()注冊(cè)的處理程序可能按照任何順序調(diào)用,所以代碼不應(yīng)該依賴于調(diào)用順序

3.事件傳播

  在調(diào)用在目標(biāo)元素上注冊(cè)的事件處理函數(shù)后,大部分事件會(huì)“冒泡”到DOM樹根。調(diào)用目標(biāo)的父元素的事件處理程序,然后調(diào)用在目標(biāo)的祖父元素上注冊(cè)的事件處理程序。這會(huì)一直到Document對(duì)象,最后到達(dá)Window對(duì)象。

  發(fā)生在文檔元素上的大部分事件都會(huì)冒泡,值得注意的例外是focus、blur和scroll事件。文檔元素的load事件會(huì)冒泡,但它會(huì)在Document對(duì)象上停止冒泡而不會(huì)傳播到Window對(duì)象。只有當(dāng)整個(gè)文檔都加載完畢時(shí)才會(huì)觸發(fā)Window對(duì)象的load事件。

4.取消事件默認(rèn)行為、阻止事件傳播

      在支持addEventListener()的瀏覽器中,可以通過調(diào)用事件對(duì)象的preventDefault()方法取消事件的默認(rèn)操作。IE9之前的IE中,可以通過設(shè)置事件對(duì)象的returnValue屬性為false達(dá)到同樣的效果。下面一段代碼是結(jié)合三種技術(shù)取消事件:

function cancelHandler(event){
 var event=event||window.event;//兼容IE
 //取消事件相關(guān)的默認(rèn)行為
 if(event.preventDefault) //標(biāo)準(zhǔn)技術(shù)
 event.preventDefault();
 if(event.returnValue) //兼容IE9之前的IE
 event.returnValue=false;
 return false; //用于處理使用對(duì)象屬性注冊(cè)的處理程序
}

取消事件相關(guān)的默認(rèn)操作只是事件取消中的一種,我們也能取消事件傳播。在支持addEventListener()的瀏覽器中,可以調(diào)用事件對(duì)象的stopPropagation()方法以阻止事件的繼續(xù)傳播。如果在同一對(duì)象上定義了其他處理程序,剩下的處理程序?qū)⒁琅f被調(diào)用,但調(diào)用stopPropagation()之后任何其他對(duì)象上的事件處理程序?qū)⒉粫?huì)被調(diào)用。

 IE9之前的IE不支持stopPropagation()方法,而是設(shè)置事件對(duì)象cancelBubble屬性為true來實(shí)現(xiàn)阻止事件進(jìn)一步傳播。

好了以上就是小編為大家整理的全部內(nèi)容啦,希望對(duì)大家有所幫助~

相關(guān)文章

  • 使用Math.floor與Math.random取隨機(jī)整數(shù)的方法詳解

    使用Math.floor與Math.random取隨機(jī)整數(shù)的方法詳解

    本篇文章對(duì)使用Math.floor與Math.random取隨機(jī)整數(shù)的方法進(jìn)行了詳細(xì)的分析介紹。需要的朋友參考下
    2013-05-05
  • JavaScript基本對(duì)象

    JavaScript基本對(duì)象

    JavaScript基本對(duì)象...
    2007-01-01
  • jQuery入門問答 整理的幾個(gè)常見的初學(xué)者問題

    jQuery入門問答 整理的幾個(gè)常見的初學(xué)者問題

    大家可能看到了,我已經(jīng)將過去寫的兩篇jQuery的教程刪掉了,因?yàn)楦郊淮嬖诹说鹊葐栴},所以刪除了,從今天開始我就寫jQuery教程第二版了!希望大家能夠支持我!
    2010-02-02
  • Javascript基礎(chǔ)教程之定義和調(diào)用函數(shù)

    Javascript基礎(chǔ)教程之定義和調(diào)用函數(shù)

    這篇文章主要介紹了Javascript基礎(chǔ)教程之定義和調(diào)用函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2015-01-01
  • JS 面向?qū)ο笾^承---多種組合繼承詳解

    JS 面向?qū)ο笾^承---多種組合繼承詳解

    下面小編就為大家?guī)硪黄狫S 面向?qū)ο笾^承---多種組合繼承詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-07-07
  • javascript三種代碼注釋方法

    javascript三種代碼注釋方法

    本文主要介紹javascript中三種常見的代碼注釋的方法,希望能夠幫到大家。
    2016-06-06
  • js中document.write的那點(diǎn)事

    js中document.write的那點(diǎn)事

    document.write()方法可以用在兩個(gè)方面:頁面載入過程中用實(shí)時(shí)腳本創(chuàng)建頁面內(nèi)容,以及用延時(shí)腳本創(chuàng)建本窗口或新窗口的內(nèi)容。該方法需要一個(gè)字符串參數(shù),它是寫到窗口或框架中的HTML內(nèi)容。這些字符串參數(shù)可以是變量或值為字符串的表達(dá)式,寫入的內(nèi)容常常包括HTML標(biāo)記語言
    2014-12-12
  • JavaScript中的跨瀏覽器事件操作的基本方法整理

    JavaScript中的跨瀏覽器事件操作的基本方法整理

    首先值得說一下,在事件處理、事件對(duì)象、阻止事件的傳播等方法或?qū)ο蟠嬖谥鵀g覽器兼容性問題,開發(fā)過程中最好編寫成一個(gè)通用的事件處理工具,嗯,接下來我們一起來看一下JavaScript中的跨瀏覽器事件操作的基本方法整理
    2016-05-05
  • JS Date函數(shù)整理方便使用

    JS Date函數(shù)整理方便使用

    JS Date 對(duì)象用于處理日期和時(shí)間,在項(xiàng)目中使用很廣泛,下面是本文對(duì)JS Date函數(shù)的整理,感興趣的朋友可以參考下
    2013-10-10
  • JavaScript 事件對(duì)象介紹

    JavaScript 事件對(duì)象介紹

    這篇文章主要介紹了JavaScript 事件對(duì)象介紹,需要的朋友可以參考下
    2015-04-04

最新評(píng)論