javaScript事件流是什麼?

来源:https://www.cnblogs.com/oliverchen1/archive/2018/01/04/8192218.html
-Advertisement-
Play Games

一、事件 事件是文檔或者瀏覽器視窗中發生的,特定的交互瞬間。 事件是用戶或瀏覽器自身執行的某種動作,如click,load和mouseover都是事件的名字。 事件是javaScript和DOM之間交互的橋梁。 你若觸發,我便執行——事件發生,調用它的處理函數執行相應的JavaScript代碼給出響 ...


一、事件

事件是文檔或者瀏覽器視窗中發生的,特定的交互瞬間。

事件是用戶或瀏覽器自身執行的某種動作,如click,load和mouseover都是事件的名字。

事件是javaScript和DOM之間交互的橋梁。

你若觸發,我便執行——事件發生,調用它的處理函數執行相應的JavaScript代碼給出響應。

典型的例子有:頁面載入完畢觸發load事件;用戶單擊元素,觸發click事件。

二、事件流

事件流描述的是從頁面中接收事件的順序。

1、事件流感性認識

問題:單擊頁面元素,什麼樣的元素能感應到這樣一個事件?

答案:單擊元素的同時,也單擊了元素的容器元素,甚至整個頁面。

例子:有三個同心圓, 給每個圓添加對應的事件處理函數,彈出對應的文字。單擊最裡面的圓,同時也單擊了外面的圓,所以外面圓的click事件也會被觸發。

 View Code

 效果如下:

  

2、事件流

事件發生時會在元素節點與根節點之間按照特定的順序傳播,路徑所經過的所有節點都會收到該事件,這個傳播過程即DOM事件流。

1、兩種事件流模型

事件傳播的順序對應瀏覽器的兩種事件流模型:捕獲型事件流和冒泡型事件流。

冒泡型事件流:事件的傳播是從最特定事件目標到最不特定的事件目標。即從DOM樹的葉子到根。【推薦】

捕獲型事件流:事件的傳播是從最不特定事件目標到最特定的事件目標。即從DOM樹的根到葉子。

事件捕獲的思想就是不太具體的節點應該更早接收到事件,而最具體的節點最後接收到事件。

複製代碼
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
<div id="myDiv">Click me!</div>
</body>
</html>
複製代碼

上面這段html代碼中,單擊了頁面中的<div>元素,

在冒泡型事件流中click事件傳播順序為<div>—》<body>—》<html>—》document

在捕獲型事件流中click事件傳播順序為document—》<html>—》<body>—》<div>

 

note:

1)、所有現代瀏覽器都支持事件冒泡,但在具體實現中略有差別:

IE5.5及更早版本中事件冒泡會跳過<html>元素(從body直接跳到document)。

IE9、Firefox、Chrome、和Safari則將事件一直冒泡到window對象。

2)、IE9、Firefox、Chrome、Opera、和Safari都支持事件捕獲。儘管DOM標準要求事件應該從document對象開始傳播,但這些瀏覽器都是從window對象開始捕獲事件的。

3)、由於老版本瀏覽器不支持,很少有人使用事件捕獲。建議使用事件冒泡

2、DOM事件流

DOM標準採用捕獲+冒泡。兩種事件流都會觸發DOM的所有對象,從document對象開始,也在document對象結束。

DOM標準規定事件流包括三個階段:事件捕獲階段、處於目標階段和事件冒泡階段。

  • 事件捕獲階段:實際目標(<div>)在捕獲階段不會接收事件。也就是在捕獲階段,事件從document到<html>再到<body>就停止了。上圖中為1~3.
  • 處於目標階段:事件在<div>上發生並處理。但是事件處理會被看成是冒泡階段的一部分
  • 冒泡階段:事件又傳播迴文檔。

note:

1)、儘管“DOM2級事件”標準規範明確規定事件捕獲階段不會涉及事件目標,但是在IE9、Safari、Chrome、Firefox和Opera9.5及更高版本都會在捕獲階段觸發事件對象上的事件。結果,就是有兩次機會在目標對象上面操作事件。

2)、並非所有的事件都會經過冒泡階段 。所有的事件都要經過捕獲階段和處於目標階段,但是有些事件會跳過冒泡階段:如,獲得輸入焦點的focus事件和失去輸入焦點的blur事件。

兩次機會在目標對象上面操作事件例子:

 View Code

運行效果就是會陸續彈出6個框,為說明原理我整合成了一個圖:

3、事件流的典型應用事件代理

傳統的事件處理中,需要為每個元素添加事件處理器。js事件代理則是一種簡單有效的技巧,通過它可以把事件處理器添加到一個父級元素上,從而避免把事件處理器添加到多個子級元素上。

1、事件代理

事件代理的原理用到的就是事件冒泡和目標元素,把事件處理器添加到父元素,等待子元素事件冒泡,並且父元素能夠通過target(IE為srcElement)判斷是哪個子元素,從而做相應處理。關於target更多內容請參考javaScript事件(四)event的公共成員(屬性和方法) 下麵舉例來說明。

傳統事件處理,為每個元素添加事件處理器,代碼如下:

 View Code

事件代理的處理方式,代碼如下:

複製代碼
<body>
<ul id="color-list">
<li>red</li>
<li>orange</li>
<li>yellow</li>
<li>green</li>
<li>blue</li>
<li>indigo</li>
<li>purple</li>
</ul>
<script>
(function(){
    var colorList=document.getElementById("color-list");
    colorList.addEventListener('click',showColor,false);
    function showColor(e)
    {
        e=e||window.event;
        var targetElement=e.target||e.srcElement;
        if(targetElement.nodeName.toLowerCase()==="li"){
        alert(targetElement.innerHTML);
        }
    }
})();
</script>
</body>
複製代碼

2、事件代理的好處

 總結一下事件代理的好處:

  • 將多個事件處理器減少到一個,因為事件處理器要駐留記憶體,這樣就提高了性能。想象如果有一個100行的表格,對比傳統的為每個單元格綁定事件處理器的方式和事件代理(即table上添加一個事件處理器),不難得出結論,事件代理確實避免了一些潛在的風險,提高了性能。
  • DOM更新無需重新綁定事件處理器,因為事件代理對不同子元素可採用不同處理方法。如果新增其他子元素(a,span,div等),直接修改事件代理的事件處理函數即可,不需要重新綁定處理器,不需要再次迴圈遍歷。

3、事件代理的問題:【update20170502】

代碼如下:事件代理同時綁定了li和span,當點擊span的時候,li和span都會冒泡。

複製代碼
<li><span>li中的span的內容</span></li>

<script>
    $(document).on('click', 'li', function(e){
        alert('li li');
    });

    $(document).on('click', 'span', function(e){
        alert('li span');
    })
</script>
複製代碼

解決辦法:

方法一:span的事件處理程式中阻止冒泡

 $(document).on('click', 'span', function(e){
        alert('li span');
        e.stopPropagation();
    })

方法二:li的事件處理程式中檢測target元素

複製代碼
 $(document).on('click', 'li', function (e) {
        if (e.target.nodeName == 'SPAN') {
            e.stopPropagation();
            return;
        }
        alert('li li');
    });
複製代碼

4、事件代理的一個有趣應用【update20170502】

點擊一個列表時,輸出對應的索引

複製代碼
<script>
    var ul=document.querySelector('ul');
    var lis=ul.querySelectorAll('ul li');
    ul.addEventListener('click', function (e) {
        var target= e.target;
        if(target.nodeName.toUpperCase()==='LI'){
            alert([].indexOf.call(lis,target));
        }
    },false)
</script>
複製代碼

 

 

擴展閱讀:

三、事件處理程式

四、IE事件處理程式

這兩部分內容見javaScript事件(二)事件處理程式

五、事件對象

這部分內容見javaScript事件(三)事件對象

六、事件對象的公共成員

這部分內容見javaScript事件(四)event的公共成員(屬性和方法)

七、滑鼠事件

這部分內容見javaScript事件(五)事件類型之滑鼠事件

原文鏈接:http://www.cnblogs.com/starof/p/4066381.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最簡單的方式就是創建一個文本文檔,然後將.txt尾碼改為.html或者htm。 完成上面的步驟會創建一個完全空白的網頁,下麵填充一點內容,代碼實例如下: 上面的代碼會創建一個顯示"螞蟻部落"的網頁。 網頁的具體結構和元素組成會在後面的章節分步介紹。 http://www.softwhy.com/ar ...
  • 一.背景介紹: css不是一種真正意義上的編程語言,不具有編程語言的變數、迴圈、遍歷和繼承等特性。 為瞭解決css的這些缺點,能夠對css進行預處理的"中間語言"就產生了,以此來實現某些編程特性。 也就是在編寫中間語言過程中,可以使用編程方式和思維,中間語言不能直接被瀏覽器所解析。 最後將這個中間語 ...
  • 一.正則表達式基本介紹: 實際應用中,經常需要按照某些規則去操作字元串,正則表達式恰好是制定這些規則的利器。 正則表達的英文全程是regular expression,正如它的名字,可以將它分為兩個部分來理解: (1).第一部分是規則(regular),用來約束各個字元的語義。例如點(.)可以表示任 ...
  • 一.jQuery是什麼: 它是一個輕量級的JavaScript庫。所以遵循JavaScript語法,並具有自身的特點。 二.jQuery的優勢: (1).具有良好的瀏覽器相容性,所有主流瀏覽器對jQuery有著良好支持。 (2).實現了腳本與頁面分離,頁面更加清晰,也有利於搜索引擎優化。 (3).高 ...
  • 首先,vue和阿裡雲oss上傳圖片結合參考了 這位朋友的 https://www.jianshu.com/p/645f63745abd 文章,成功的解決了我用阿裡雲oss上傳圖片前的一頭霧水。 該大神文章里有寫github地址,裡面的2.0分支採用vue2.0實現,只不過這個上傳圖片用的是分片上傳, ...
  • 三種本地存儲方式 cookie 前言 網路早期最大的問題之一是如何管理狀態。簡而言之,伺服器無法知道兩個請求是否來自同一個瀏覽器。當時最簡單的方法是在請求時,在頁面中插入一些參數,併在下一個請求中傳回參數。這需要使用包含參數的隱藏的表單,或者作為URL參數的一部分傳遞。這兩個解決方案都手動操作,容易 ...
  • 網上查找,問題可能是 id有重覆 經排查,沒有發現重覆id 解決方案 form表單中每個input框都沒有name屬性,添加name屬性即可 若name屬性與jQuery的關鍵字有衝突,也可導致該問題 ...
  • 在 CSS 中設置字體名稱,直接寫中文是可以的。但是在文件編碼(GB2312、UTF-8 等)不匹配時會產生亂碼的錯誤。 為此,在 CSS 直接使用 Unicode 編碼來寫字體名稱可以避免這些錯誤。使用 Unicode 寫中文字體名稱,瀏覽器是可以正確的解析的。 例如: font-family: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...