欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS傳播事件、取消事件默認行為、阻止事件傳播詳解

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

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

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

2.調用順序

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

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

3.事件傳播

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

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

4.取消事件默認行為、阻止事件傳播

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

function cancelHandler(event){
 var event=event||window.event;//兼容IE
 //取消事件相關的默認行為
 if(event.preventDefault) //標準技術
 event.preventDefault();
 if(event.returnValue) //兼容IE9之前的IE
 event.returnValue=false;
 return false; //用于處理使用對象屬性注冊的處理程序
}

取消事件相關的默認操作只是事件取消中的一種,我們也能取消事件傳播。在支持addEventListener()的瀏覽器中,可以調用事件對象的stopPropagation()方法以阻止事件的繼續(xù)傳播。如果在同一對象上定義了其他處理程序,剩下的處理程序將依舊被調用,但調用stopPropagation()之后任何其他對象上的事件處理程序將不會被調用。

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

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

相關文章

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

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

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

    JavaScript基本對象

    JavaScript基本對象...
    2007-01-01
  • jQuery入門問答 整理的幾個常見的初學者問題

    jQuery入門問答 整理的幾個常見的初學者問題

    大家可能看到了,我已經將過去寫的兩篇jQuery的教程刪掉了,因為附件不存在了等等問題,所以刪除了,從今天開始我就寫jQuery教程第二版了!希望大家能夠支持我!
    2010-02-02
  • Javascript基礎教程之定義和調用函數(shù)

    Javascript基礎教程之定義和調用函數(shù)

    這篇文章主要介紹了Javascript基礎教程之定義和調用函數(shù)的相關資料,需要的朋友可以參考下
    2015-01-01
  • JS 面向對象之繼承---多種組合繼承詳解

    JS 面向對象之繼承---多種組合繼承詳解

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

    javascript三種代碼注釋方法

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

    js中document.write的那點事

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

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

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

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

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

    JavaScript 事件對象介紹

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

最新評論