08 . 12/3 事件對象

来源:https://www.cnblogs.com/jinfeixiang/archive/2018/12/03/10060383.html
-Advertisement-
Play Games

12.3事件對象 1.每個元素身上的事件都是天生自帶的,不需要我們去定義,只需要我們給這個事件綁定一個方法, 2.事件綁定的寫法 1.div.onclick=function(){} DOM 0級事件綁定 2.div.addEventListener()或div.attachEvent() DOM2 ...


12.3事件對象

1.每個元素身上的事件都是天生自帶的,不需要我們去定義,只需要我們給這個事件綁定一個方法,

2.事件綁定的寫法

    1.div.onclick=function(){}  DOM 0級事件綁定

    2.div.addEventListener()或div.attachEvent() DOM2 級事件綁定

    二者的區別

    onclick是這個元素私有的屬性,天生自帶的,而addEventListener()是公有屬性,從EvenTarget(事件源)對象繼承來的

Ie低版本的attachEvent是公有的。

div.onclick 存在事件冒泡機制沒有捕獲機制

div.addEventListener()可有冒泡可有捕獲

div.attachEvent()只有冒泡機制

4.div.addEventListener和div.attachEvent的區別

1.前者有冒泡和捕獲機制,後者只有冒泡機制

2.前者事件名不帶on,後者帶on

3.前者this指向當前元素,後者指向window

4.前者是標準瀏覽器的寫法,後者是ie8一下

Arguments

每個函數都有一個arguments對象,它是這個函數所有參數構成的集合

上面的控制台是arguments數組中有元素叫mouseevent

所以,每個事件的方法中瀏覽器都給他一個參數叫mouseevent。我們所有滑鼠的信息都臨時存儲在這個mouseevent對象上

Mouseevent有相容性

標準瀏覽器可以直接讀取,但是ie不行

解決辦法

Evenet對象的相容性

Event對象的相容性

clientX和clientY是滑鼠到瀏覽器視窗左上角的距離坐標

pageX和pageY是滑鼠到網頁左上角的距離坐標,但是ie低版本沒有這個屬性

ie下怎麼算pageY的值 用clientY+scrollTop

事件源 點擊哪個元素,哪個元素就是事件源

標準瀏覽器的事件源是ev.target

Ie6-8沒有這個屬性 但是ie有ev.srcElement

阻止事件冒泡相容性

1.event.cancelBubble=true

2.event.stopPropagation?event.stopPropagation():event.cancelBubble=true

阻止事件預設行為相容性

比如 a的href

Href為空 會自動刷新頁面

Href為# 錨點跳轉

Href為javascript:;阻止預設行為的發生

Event.preventDefault?Event.preventDefault():event.returnValue=false

事件委托

如果子元素身上綁定大量相同的事件,我們儘量採用事件委托,所有子元素把自己的事件委托給父級了。

原理:採用事件冒泡機制完成

為什麼使用事件委托呢

傳統的for迴圈綁定事件,會增加大量的dom操作(事件),影響頁面性能,採用事件委托就是把所有的事件基於一個元素上

事件委托和傳統的事件綁定的優勢

傳統的事件綁定對新增元素不起作用,事件委托起作用

傳統的事件綁定,有多少元素js就需綁定多少事件,事件委托只需要一個事件

案例

事件委托建議採納

5.並不是所有的事件都存在事件冒泡

onmouseenter onmouseleave就沒有事件冒泡機制

所有我們跟隨滑鼠的時候儘量用這兩個事件,不要mouseover mouseout

 

作者:晉飛翔

QQ:318080891

 


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

-Advertisement-
Play Games
更多相關文章
  • 轉載請標明出處:https://www.cnblogs.com/tangZH/p/10060573.html 從gitlab上面把項目拉下來之後,用as打開,發現as無法關聯git,沒有git相關的菜單。 最終發現是因為沒有打開這個: 設置之後就可以了。 ...
  • In August 2015, Google announced the release of Android Mobile Vision API. At that time this API had mainly three components Face Detection, Barcode s... ...
  • 一、修改點擊的動畫 函數: 這是預設的點擊的動畫 我們用代碼修改一下: 這是之後的效果: 二、設置下劃線指示器的寬度不要填充完(動態的根據TabView的寬度來設置自身的寬度) 函數: 這是預設的效果 我們用代碼修改一下: 這是之後的效果: 三、設置下劃線指示器的樣式 函數: 這是預設的效果 我們用 ...
  • "覓知音"這個APP的第一個版本從提交審核到上架,歷時三個星期,其中遇到一些審核上的問題,它的處理或許能幫助到遇到同樣問題的小伙伴們,所以這裡列舉出來,這三個星期如何跟蘋果的審核團隊“鬥智鬥勇”。 ...
  • 力有不逮的對象 眾所周知,在 中,直接修改對象屬性的值無法觸發響應式。當你直接修改了對象屬性的值,你會發現,只有數據改了,但是頁面內容並沒有改變。 這是什麼原因? 原因在於: 的響應式系統是基於 這個方法的,該方法可以監聽對象中某個元素的獲取或修改,經過了該方法處理的數據,我們稱其為響應式數據。但是 ...
  • 聲明 本系列文章內容全部梳理自以下幾個來源: 《JavaScript權威指南》 "MDN web docs" "Github:smyhvae/web" "Github:goddyZhao/Translation/JavaScript" 作為一個前端小白,入門跟著這幾個來源學習,感謝作者的分享,在其基 ...
  • 方法一:footer高度固定+絕對定位 HTML代碼: CSS代碼: 實現的效果: 首先,設置body的高度至少充滿整個屏幕,並且body作為footer絕對定位的參考節點; 其次,設置main(footer前一個兄弟元素)的padding-bottom值大於等於footer的height值,以保證 ...
  • 學習Vue的一些總結,第一次寫博客,文筆實在是很差 不過我會不斷寫的。 這裡只寫了一部分常用的vue的指令,後面還會有的。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...