DOM 事件流詳解_基礎知識
1.冒泡型事件
瀏覽器的事件模型分為兩種:捕獲型事件和冒泡型事件。由於ie不支援捕獲型事件,以下主要以冒泡型事件作為講解。
(dubbed bubbling)冒泡型指事件安裝最特定的事件到最不特定的事件逐一觸發。
以上三個函數都加入了onclick函數,單機p元素後三個函數都觸發,先執行了p元素,再執行了div,最後執行了body
這這裡順便提醒下捕獲型事件,它的順序正好和冒泡型事件相反。
2.事件監聽
一個事件都需要函數來回應,這類函數通常稱為事件處理函數(enent handler),從另一個角度看,這些函數都在即時監聽著是否有事件發生,通常稱為事件監聽函數( enevt listener),事件監聽函數對於不同的瀏覽器差異較大。
i.通用監聽方法,例如使用onclick方法,幾乎每個標籤都支援此方法。而且瀏覽器相容性都很高
考慮到行為,事件分離。
一般使用以下方式監聽
以上介紹的兩者方法都十分便捷,在製作處理一些小功能時都被光大開發者所喜愛。但對於同一個事件。他們都只能加入一個函數,列如對於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()刪除監聽函數,使其下次點擊後再不執行。
iii.新增多個監聽事件(ie)
Click Me
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的事件監聽方法:
Click Me
具體的執行順序大家可測試。
以上就是本文的全部內容了,希望大家能夠喜歡。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

dom是一種文件物件模型,同時也是用於html程式設計的接口,透過dom來操作頁面中的元素。 DOM是HTML文件的記憶體中物件表示,它提供了使用JavaScript與網頁互動的方式。 DOM是節點的層次結構(或樹),其中document節點為根。

vue3ref綁定dom或元件失敗原因分析場景描述在vue3中常用到使用ref綁定元件或dom元素的情況,很多時候,明明使用ref綁定了相關元件,但是經常ref綁定失敗的情況。 ref綁定失敗情況舉例ref綁定失敗的絕大多數情況是,在ref和元件綁定的時候,該元件還未渲染,所以綁定失敗。或是元件剛開始未渲染,ref未綁定,當元件開始渲染,ref也開始綁定,但是ref和元件並未綁定完成,這個時候使用元件相關的方法就會出現問題。 ref綁定的元件使用了v-if,或他的父元件使用了v-if導致頁面

1.原生js取得DOM節點:document.querySelector(選擇器)document.getElementById(id選擇器)document.getElementsByClassName(class選擇器)....2.vue2中取得目前元件的實例物件:因為每個vue的元件實例上,都包含一個$refs對象,裡面儲存著對應的DOM元素或元件的參考。所以在預設情況下,元件的$refs指向一個空物件。可以先在元件上加上ref="名字",然後透過this.$refs.

dom和bom物件有:1、「document」、「element」、「Node」、「Event」和「Window」等5種DOM物件;2、「window」、「navigator」、「location」、「history」和「screen」等5種BOM物件。

在網頁開發中,DOM(DocumentObjectModel)是一個非常重要的概念。它可以讓開發者輕鬆地對一個網頁的HTML或XML文件進行修改和操作,例如新增、刪除、修改元素等。而PHP內建的DOM操作庫也為開發者提供了豐富的功能,本文將介紹PHP中的DOM操作指南,希望可以幫助大家。 DOM的基本概念DOM是一個跨平台、獨立於語言的API,它可以將

bom和dom在作用和功能、與JavaScript的關係、相互依賴性、不同瀏覽器的兼容性和安全性考量等方面都有區別。詳細介紹:1、作用和功能,BOM的主要作用是操作瀏覽器窗口,它提供了瀏覽器窗口的直接訪問和控制,而DOM的主要作用則是將網頁文檔轉換為一個對象樹,允許開發者透過這個物件樹來取得和修改網頁的元素和內容;2、與JavaScript的關係等等。

dom 內建物件有:1、document;2、window;3、navigator;4、location;5、history;6、screen;7、document.documentElement;8、document.body;9、document.head;10、document .title;11、文檔.cookie。

DOM實現了對網頁內容的動態訪問和更新,BOM則提供了與瀏覽器視窗進行交互的API,包括控制瀏覽器的行為、獲取瀏覽器和用戶環境的信息,DOM主要用於操作網頁內容,而BOM則主要用於操作瀏覽器視窗和與瀏覽器交互,兩者共同構成了Web前端開發中重要的基礎,為開發者提供了豐富的方法來控制和操作網頁及瀏覽器,實現交互性強、使用者體驗良好的Web應用程式。
