精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

盤點JavaScript中的事件及事件的三種模型

開發 前端
我們知道在很多編程語言都有事件這個概念,在JavaScript中同樣存在事件,原因也很簡單,我們知道HTML是頁面結構層,相當于人的骨架。

[[434502]]

大家好,我是皮皮。

前言

我們知道在很多編程語言都有事件這個概念,在JavaScript中同樣存在事件,原因也很簡單,我們知道HTML是頁面結構層,相當于人的骨架;

CSS是樣式層,相當于人的外形;但是它是靜態的,一個人應該能動,動起來,所以產生了JavaScript;JavaScript就是用來控制頁面元素,與用戶產

生動態交互效果,才構成了如今這豐富多樣化的界面。今天我們就來認識一下js當中的事件;

一、事件相關概念

事件:指用戶的鼠標動作和鍵盤動作,document的load和unloaded,事件被封裝成一個event對象,包含了該事件發生時的所有相關信息(event的屬性)以及可以對事件進行的操作(event的方法)。

比如點擊頁面上一個按鈕,產生的event對象如下:

以上可以看到是一個MouseEvent對象,包含了一系列屬性,如鼠標點擊的位置等。

敲擊鍵盤時產生的event對象

window.onload監聽函數中打印出event對象如下:

注意:Event 類是MouseEvent、KeyboardEvent的父類;

二、事件對象常用屬性和方法

2.1事件定位相關屬性

MouseEvent對象里的屬性,很多帶X/Y,它們都和事件的位置相關。具體包括:x/y、clientX/clientY、pageX/pageY、screenX/screenY、layerX/layerY、offsetX/offsetY 六對;之所以能有這么多是因為各瀏覽器廠商在版本更迭的時候產生了很多不一致:

以移動鼠標為例:

x屬性 Y屬性 功能
x Y 距瀏覽器可視區域(工具欄除外區域)左/上的距離;
clientX clientY 距瀏覽器可視區域(工具欄除外區域)左/上的距離(同上);
screenX screenY 距計算機顯示器左/上的距離,拖動你的瀏覽器窗口位置可以看到變化;
offsetX offsetY 距有定位屬性的父元素左/上的距離;(不計算邊框)
pageX pageY 距頁面左/上的距離,它與clientX/clientY的區別是不隨滾動條的位置變化;
layerX layerY 距有定位屬性的父元素左/上的距離(計算邊框);

之所以有那么多值一樣的情況,就是由于瀏覽器兼容的原因, 針對于瀏覽器對于不同屬性的兼容情況如下所示;(+支持,-不支持)

瀏覽器 offsetX/offsetY x/y layerX/layerY pageX/pageY clientX/clientY screenX/screenY
W3C - - - - + +
IE + + - - + +
Firefox - - + + + +
Opera + + - + + +
Safari + + + + + +
chrome + +   + + +

說明:詳情可查

https://www.caniuse.com/

2.2其他常用屬性

  • target:發生事件的節點;
  • currentTarget:當前正在處理的事件的節點,在事件捕獲或冒泡階段;
  • timeStamp:事件發生的時間,時間戳。
  • bubbles:事件是否冒泡。
  • cancelable:事件是否可以用preventDefault()方法來取消默認的動作;
  • keyCode:按下的鍵的值;

2.3 event對象的方法

event. preventDefault(): 阻止元素默認的行為,如鏈接的跳轉、表單的提交;

event. stopPropagation(): 阻止事件冒泡;

event.initEvent(): 初始化新事件對象的屬性,自定義事件會用,不常用;

event. stopImmediatePropagation(): 可以阻止掉同一事件的其他優先級較低的偵聽器的處理很少使用;

三、事件的三種模型

3.1 原始事件模型(DOM0級)

在原始事件模型中,事件發生后沒有傳播的概念,沒有事件流。事件發生,馬上處理。監聽函數只是元素的一個屬性值,通過指定元素的屬性值來綁定監聽器。書寫方式有兩種:

HTML代碼中指定屬性值:

  1. <input type="button" onclick="func1()" /> 

在js代碼中指定屬性值:

  1. document.getElementsByTagName(‘input’)[0].onclick = func1 

優點:所有瀏覽器都兼容

缺點:

  • 邏輯與顯示沒有分離;
  • 相同事件的監聽函數只能綁定一個,后綁定的會覆蓋掉前面的,如:a.onclick = func1; a.onclick = func2;將只會執行func2中的內容;
  • 無法通過事件的冒泡、委托等機制完成更多事情;

3.2 IE事件模型

“IE不把該對象傳入事件處理函數,由于在任意時刻只會存在一個事件,所以IE把它作為全局對象window的一個屬性”,用IE8執行了代碼alert(window.event),結果彈出是null,說明該屬性已經定義,只是值為null(與undefined不同),代碼如下;

  1. window.onload = function (){alert(window.event);} 
  2.  
  3. setTimeout(function(){alert(window.event);},2000); 

第一次彈出【object event】,兩秒后彈出依然是null。由此可見IE是將event對象在處理函數中設為window的屬性,一旦函數執行結束,便被置為null了;

IE的事件模型只有兩步:

  • 先執行元素的監聽函數,
  • 然后事件沿著父節點一直冒泡到document。

IE模型下的事件監聽方式比較獨特,綁定監聽函數的方法是:

  1. attachEvent( "eventType""handler");//其中evetType為事件的類型, 

如onclick,注意要加’on’。解除事件監聽器的方法是:

  1. detachEvent("eventType""handler" ) 

IE的事件模型已經可以解決原始模型的三個缺點,但其自己的缺點就是兼容性,只有IE系列瀏覽器才可以這樣寫。

3.2 DOM2事件模型

此模型是W3C制定的標準模型,既然是標準,現代瀏覽器(指IE6~8除外的瀏覽器)都已經遵循這個規范。W3C制定的事件模型中,一次事件的發生包含三個過程:

capturing phase:事件捕獲階段。事件被從document一直向下傳播到目標元素,在這過程中依次檢查經過的節點是否注冊了該事件的監聽函數,若有則執行;

target phase:事件處理階段。事件到達目標元素,執行目標元素的事件處理函數;

bubbling phase:事件冒泡階段。事件從目標元素上升一直到達document,同樣依次檢查經過的節點是否注冊了該事件的監聽函數,有則執行;

所有的事件類型都會經歷captruing phase但是只有部分事件會經歷bubbling phase階段,例如submit事件就不會被冒泡。

標準的事件監聽器綁定:

  1. addEventListener("eventType""handler""true|false"); 

其中eventType指事件類型。第二個參數是處理函數,第三個即用來指定是否在捕獲階段進行處理,一般設為false來與IE保持一致。

監聽器的解除也類似:

  1. removeEventListner("eventType""handler""true!false"); 

以上便是事件的三種模型,我們在開發的時候需要兼顧IE與非IE瀏覽器,所以注冊一個監聽器應該這樣寫:

  1. var a = document.getElementById('a'); 
  2.  
  3. if(a.attachEvent){ 
  4.  
  5. a.attachEvent('onclick',func); 
  6.  
  7.  
  8. else
  9.  
  10. a.addEventListener('click',func,false); 
  11.  

四、總結

本文我們就JavaScript事件做了基本介紹,認識了事件的相關概念,事件的常用屬性和方法,以及事件的三種模型,想要完成復雜的界面動態交互效果,事件的使用至關重要,想要深入了解事件的小伙伴可以參考官方手冊。

 

http://www.javascriptcn.com/

 

責任編輯:武曉燕 來源: IT共享之家
相關推薦

2025-03-19 10:22:09

JavaScript編程語言開發

2020-11-01 17:10:46

異步事件開發前端

2012-03-26 12:23:25

JavaSwing

2009-06-09 16:53:22

Java Swing處理方法比較

2021-08-10 10:14:14

存儲接口存儲設備存儲

2011-06-16 14:38:18

JavaScript事件委托

2010-07-06 09:59:06

SQL Server事

2023-12-19 16:43:01

2009-06-17 09:48:11

javascript手事件參考

2022-11-30 15:15:48

2021-08-03 10:01:37

JavaScript事件方法

2024-08-02 15:04:14

JavaScript服務器

2024-06-25 12:52:40

JavaScript開發

2021-02-03 18:05:30

Python方法列表

2021-02-06 11:26:55

Python開發list

2023-10-13 00:00:00

Redis模塊空間對象

2022-01-04 16:50:47

JavaScript圖片網站

2021-10-13 09:02:05

Python中文亂碼Python基礎

2016-06-12 10:37:32

云計算私有云公有云

2023-06-12 07:50:45

點贊
收藏

51CTO技術棧公眾號

伊人久久亚洲热| 精品国产欧美| 久久先锋影音av鲁色资源| 日本久久久a级免费| 欧美波霸videosex极品| 亚洲精品第一| 黄色成人在线免费| 日韩精品另类天天更新| 精品国自产在线观看| 久久国产精品毛片| 久久国产精品亚洲| 精品无码一区二区三区| 91精品视频一区二区| 黑人巨大精品欧美一区二区免费| 亚洲最新在线| 三级视频在线| 国产成人在线网站| 国产精国产精品| 中文字幕一区二区三区手机版| 日韩久久视频| 亚洲人成电影网| 白嫩情侣偷拍呻吟刺激| 日本一区二区中文字幕| 亚洲国产成人高清精品| 午夜啪啪福利视频| 国产在线一在线二| 99久久国产综合精品女不卡| 亚洲影院污污.| 亚洲性在线观看| 天堂成人国产精品一区| 国外色69视频在线观看| 农村妇女精品一区二区| 欧美mv日韩| 亚洲一区第一页| 中文精品在线观看| 老司机aⅴ在线精品导航| 欧美一区二区久久久| 国产又猛又黄的视频| 澳门成人av网| 日韩欧美国产骚| 欧美成人免费在线观看视频| 四季久久免费一区二区三区四区| 国产精品不卡视频| 香蕉久久夜色| 成人激情电影在线看| 久久欧美中文字幕| 日本精品免费| 国产51人人成人人人人爽色哟哟| 91毛片在线观看| 精品一区久久久久久| 四虎在线视频免费观看| 国产91在线观看丝袜| 99视频国产精品免费观看| 精品人妻久久久久一区二区三区 | 国内外免费激情视频| 国产精品一二三产区| 亚洲成人tv网| 国自产拍偷拍精品啪啪一区二区| 波多野结衣在线播放| 亚洲一区二区三区四区中文字幕| 日韩精品免费一区| 国产美女一区视频| 亚洲成人午夜电影| 可以在线看的av网站| 久久uomeier| 在线观看日韩精品| 天堂av8在线| 日韩一区二区三区色| 精品少妇一区二区三区视频免付费| 永久av免费在线观看| 99久热这里只有精品视频免费观看| 日韩欧美卡一卡二| 成人在线电影网站| 蜜臀91精品国产高清在线观看| 亚洲天堂第二页| 天天摸日日摸狠狠添| 亚洲91久久| 午夜精品久久久久久久白皮肤| 欧美成人精品欧美一级乱黄| 羞羞答答国产精品www一本| 国产精品 欧美在线| 91亚洲精品国偷拍自产在线观看 | 成人性生交大片免费看小说 | 国产不卡在线视频| 精品一区二区不卡| 午夜在线视频播放| 亚洲一区二区三区国产| 男人舔女人下面高潮视频| 午夜不卡一区| 亚洲精品美女在线观看| 国产123在线| 国产精品大片免费观看| 日韩女优人人人人射在线视频| 国产精品自偷自拍| 2欧美一区二区三区在线观看视频| 亚洲精品国产一区| 免费毛片在线看片免费丝瓜视频| 色婷婷综合久久久中文一区二区| 婷婷激情小说网| 亚洲另类春色校园小说| 久久综合免费视频影院| 国产精品久免费的黄网站| 狠狠色2019综合网| 久久天天狠狠| 日本在线观看大片免费视频| 欧美视频在线不卡| 日韩理论片在线| 国产精品乱码视频| yourporn在线观看中文站| 亚洲欧美成人一区二区三区| 国产成人黄色片| 国产精品一区二区精品视频观看| 亚洲精品一区二三区不卡| 神马久久精品综合| 久久蜜桃精品| 国产欧美一区二区在线播放| 国产丝袜在线| 欧洲在线/亚洲| 国模私拍在线观看| 2023国产精品久久久精品双| 国产成人精品久久二区二区91| 亚洲精品中文字幕成人片| 国产精品久久久久久久久免费樱桃 | 丰满熟女一区二区三区| 国产精品欧美经典| 91看片就是不一样| 欧美偷窥清纯综合图区| 精品中文字幕视频| 91精品国自产| 亚洲国产精品精华液2区45| 欧美黑人经典片免费观看| 在线精品自拍| 久久天堂av综合合色| 无码人妻av免费一区二区三区| av一区二区三区四区| 成年丰满熟妇午夜免费视频 | 久久精品国产美女| 国精一区二区三区| 日韩精品综合一本久道在线视频| 亚洲人与黑人屁股眼交| 麻豆成人久久精品二区三区小说| 欧洲精品一区色| 综合在线影院| 亚洲社区在线观看| 在线免费观看国产精品| 26uuu亚洲综合色| 欧美牲交a欧美牲交aⅴ免费下载| av成人资源| 久久久久久久久综合| 欧美 日韩 国产 成人 在线| 亚洲成人av福利| 在线观看欧美一区二区| 欧美区国产区| 国产原创精品| 午夜影院在线播放| 国产午夜精品久久久| av网站中文字幕| 久久精品欧美日韩| 成人在线看视频| 蜜臀久久99精品久久一区二区| 韩国19禁主播vip福利视频| www.久久精品.com| 亚洲国产视频一区| 好男人香蕉影院| 免费日韩av片| 日韩欧美视频一区二区| 高清欧美日韩| 久久资源免费视频| 日本高清视频网站| 日本高清不卡视频| 日本精品久久久久中文| 激情偷乱视频一区二区三区| 加勒比海盗1在线观看免费国语版| 日韩成人精品| 欧美一区在线直播| 永久免费在线观看视频| 欧美一区二区三区男人的天堂| 九九九久久久久| 972aa.com艺术欧美| 日本女优爱爱视频| 99久久99视频只有精品| 高清免费日韩| 少妇一级淫免费播放 | 亚洲欧美另类人妖| 老熟妇一区二区三区啪啪| 亚洲情趣在线观看| av av在线| 青青草97国产精品免费观看无弹窗版| 亚洲在线不卡| 精品网站aaa| 国产精品亚洲美女av网站| 成人video亚洲精品| 亚洲第一中文字幕在线观看| 自拍偷拍18p| 一区二区三区蜜桃| 无码熟妇人妻av| 国产精品夜夜爽| 成人在线看视频| 欧美久久成人| 日本一区二区三区四区高清视频| 二区三区精品| 日本成熟性欧美| 色黄网站在线观看| 国产香蕉精品视频一区二区三区 | 精品视频—区二区三区免费| 一二三区中文字幕| 精品日本高清在线播放| 三级黄色录像视频| 久久精品亚洲国产奇米99| 精品人妻一区二区三区免费| 久久青草久久| 久久久久久久久久网| 一区二区三区午夜视频| 欧美凹凸一区二区三区视频| 深夜福利一区| 国产精自产拍久久久久久| 涩涩涩在线视频| 欧美成人一区二区三区电影| 成人av毛片| 国产丝袜视频一区| 少妇av在线播放| 日韩欧美色综合网站| 91久久久久国产一区二区| 狠狠色噜噜狠狠狠狠97| 久久久91视频| 自拍偷拍国产亚洲| 99久久99久久精品免费看小说.| proumb性欧美在线观看| 五月天六月丁香| 久久99精品一区二区三区三区| 亚洲国产精品毛片av不卡在线| 亚洲午夜伦理| 日本大胆人体视频| 免费看污黄网站在线观看| 久久一区二区三区四区五区 | 日本免费www| 久久久综合九色合综国产精品| 欧美性生交xxxxx| 国产suv精品一区二区6| 51自拍视频在线观看| 久久99精品久久久久久| 五月天中文字幕在线| 日韩影院在线观看| 国产熟女高潮视频| 亚洲欧美日韩精品一区二区| 国产av麻豆mag剧集| 伊人久久大香线蕉综合热线| 国产欧美久久久久| 国产一区二区三区四区老人| www.欧美黄色| 99国产精品私拍| 日韩在线综合网| 国产精品美女久久久| 青青草原av在线播放| 奶水喷射视频一区| 国产精品亚洲二区在线观看| 久久精品导航| 国产又大又黄又粗又爽| 麻豆国产欧美日韩综合精品二区 | 国产亚洲精品aa| www.黄色在线| 国产精品久久久久aaaa樱花 | 99re在线视频上| 美女福利一区二区三区| 国产99在线|中文| 免费污视频在线一区| 国产精品午夜视频| 国产精选久久| 国产乱码一区| 欧美女优在线视频| 亚洲在线欧美| 国自产拍偷拍福利精品免费一 | 337p日本欧洲亚洲大胆色噜噜| 亚洲av成人精品日韩在线播放| 亚洲欧美日韩第一区| 日本在线免费播放| 欧美激情一区二区三区在线视频观看 | 日本a在线免费观看| 国产日本精品| 午夜激情福利在线| 激情成人综合网| 日本少妇xxxx| 亚洲国产精品二十页| 破处女黄色一级片| 狠狠操狠狠色综合网| 中文字幕永久在线视频| 日韩精品一区二区三区在线观看 | 久久免费午夜影院| 久草福利资源在线| 亚洲国产综合在线| 老熟妇一区二区三区啪啪| 欧美成人性战久久| 免费成人av电影| 久久69精品久久久久久国产越南| 色一区二区三区| 亚洲综合在线做性| 在线日韩网站| 日韩精品久久一区二区| 日韩精品午夜视频| 中文字幕人妻熟女人妻a片| 国产亚洲欧美日韩在线一区| 真实国产乱子伦对白在线| 欧洲一区在线观看| 欧美熟妇另类久久久久久不卡| 伊人伊成久久人综合网小说| 丁香花在线高清完整版视频 | 日韩a在线播放| 国产一区在线看| 久久久久久久毛片| 亚洲二区视频在线| 一区二区三区午夜| 亚洲欧洲在线视频| av成人福利| 亚洲xxx视频| 成人高清电影网站| 欧美 日韩 国产在线观看| 国产精品中文字幕日韩精品| 一级特黄曰皮片视频| 精品国产91久久久久久| 精品人妻一区二区三区含羞草 | 日本成人免费在线观看| 婷婷综合另类小说色区| 精品人妻一区二区三区日产乱码| 国产一区二区美女视频| av日韩亚洲| 久久av一区二区三区亚洲| 欧美精品观看| 婷婷激情小说网| 中文字幕日韩一区| 中文字幕日本人妻久久久免费| 亚洲欧美激情四射在线日| 国产在线xxx| 国产精品国模大尺度私拍| 亚洲一区 二区 三区| 黄大色黄女片18第一次| 99re8精品视频在线观看| 亚洲深夜福利网站| 韩国成人漫画| 九九九九九精品| 亚洲国产激情| 国产婷婷在线观看| 亚洲国产精品嫩草影院| 亚洲欧美强伦一区二区| 欧美激情免费视频| 成人免费在线电影网| 大陆av在线播放| 成人一区在线观看| 国产精品第56页| 亚洲国产精品小视频| 国产直播在线| 九色一区二区| 久久久久国产精品一区二区| 成年人在线观看av| 色综合一个色综合| 日本福利在线观看| 国产成人精品视| 精品国产一区二区三区小蝌蚪 | 波多野结衣视频一区| 国产精品99精品| 亚洲美女在线观看| 国产综合色区在线观看| 西游记1978| 国产美女主播视频一区| 精品无码久久久久久久久| 亚洲国产欧美自拍| 欧美极品影院| 国产四区在线观看| 粉嫩13p一区二区三区| 中文字幕在线观看视频网站| 亚洲新声在线观看| 亚洲精品伊人| 国产婷婷一区二区三区| 久久你懂得1024| 国产口爆吞精一区二区| 久久久久久有精品国产| 欧美极品在线观看| 8x8x成人免费视频| 亚洲v中文字幕| 成人综合影院| 99一区二区| 视频一区中文字幕国产| 成年人网站在线观看视频| 欧美成人r级一区二区三区| 中文字幕在线观看1| 中文字幕成人网| 99热这里只有精品99| 91精品国产高清| 三上亚洲一区二区| 精品人妻一区二区免费| 91福利区一区二区三区| 91蜜桃在线视频| 日韩欧美一区二区视频在线播放| 国产毛片精品一区| 天天射天天干天天| 欧美精品videosex极品1| gogogo高清在线观看一区二区| 日韩欧美中文在线视频| 91福利视频在线| 成人免费观看在线观看| 最新国产精品久久|