精品欧美一区二区三区在线观看 _久久久久国色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一区| 亚洲成人一区二区三区| www.亚洲欧美| 日韩电影在线看| 国内精品一区二区三区| 国产又黄又粗视频| 91精品啪在线观看国产爱臀| 一本大道av伊人久久综合| 一区二区三区四区五区精品| 黄色av免费观看| 日本不卡视频在线观看| 午夜精品三级视频福利| 任我爽在线视频| 色综合久久中文| 日韩一区二区麻豆国产| 超碰影院在线观看| 538视频在线| 综合色中文字幕| 日韩高清国产精品| 香蕉视频国产在线| 国产成人啪免费观看软件| 国产精品精品视频一区二区三区| 久久婷婷国产麻豆91| 欧美高清视频手机在在线| 亚洲精品视频免费| 欧美日韩一区二区三区四区五区六区| 久久亚洲资源中文字| 欧美性jizz18性欧美| 日本熟妇人妻xxxx| 香蕉成人app免费看片| 国产精品福利av| 日韩三级在线播放| 欧洲亚洲精品视频| 91亚洲精品乱码久久久久久蜜桃| av资源一区二区| 国产精品自拍电影| 久久66热re国产| 国产精品日韩一区| 中文字幕久久网| 日韩电影免费在线看| 国产a∨精品一区二区三区不卡| 中文在线观看免费网站| 国产一区二区三区四区三区四| 久久久精品一区二区三区| 成年人视频软件| 日韩极品一区| 色噜噜亚洲精品中文字幕| 色欲狠狠躁天天躁无码中文字幕 | 亚洲国产一成人久久精品| 国产一区二区三区网站| 亚洲精品91在线| 日本道不卡免费一区| 中文字幕精品网| www..com.cn蕾丝视频在线观看免费版| 欧美精品第一区| 亚洲人成网站在线播| 91网站免费视频| 俺要去色综合狠狠| www.欧美免费| 欧美成人国产精品高潮| 韩日视频一区| 国产91|九色| 亚洲中文无码av在线| 男女男精品网站| 91久久国产精品| 亚洲精品一区二区三区蜜桃| av亚洲精华国产精华精华| 欧美精品尤物在线| 亚洲欧美视频一区二区| 亚洲婷婷综合久久一本伊一区| 久久最新免费视频| 51漫画成人app入口| 欧美丝袜美女中出在线| 国产高潮免费视频| 视频在线一区| 亚洲男子天堂网| 亚洲色图100p| 精品成人在线| 国产成人a亚洲精品| 亚洲一级特黄毛片| 成人一级黄色片| 日韩一区二区三区高清| 成人黄视频在线观看| 亚洲成人免费看| 黄色免费网址大全| 中文字幕日韩高清在线| 亚洲欧美日韩另类| 男女性高潮免费网站| 亚洲精选久久| 成人福利网站在线观看11| 黑人精品一区二区三区| 久久久久久电影| 日韩精品免费一区| 黄色激情在线播放| 9191国产精品| 30一40一50老女人毛片| 中文字幕av亚洲精品一部二部| 欧美一区二区三区……| 99热这里只有精品在线观看| 久久久久国产精品麻豆ai换脸 | 美洲精品一卡2卡三卡4卡四卡| 黑人精品xxx一区一二区| 三区视频在线观看| 国产精品三级| 久久久久久久久91| 亚洲一区二区天堂| 国产午夜精品福利| 男人的天堂狠狠干| 精品国产鲁一鲁****| 在线精品高清中文字幕| 全部毛片永久免费看| 国产综合色视频| 小说区图片区图片区另类灬| 国产精品电影| 欧美变态tickling挠脚心| 日本二区三区视频| 人妖欧美一区二区| 欧美精品一区二区三区在线四季 | 久久久蜜桃一区二区人| 成人午夜电影免费在线观看| 视频免费一区| 欧美色倩网站大全免费| 少妇光屁股影院| av成人国产| 好吊色欧美一区二区三区四区| 在线视频观看国产| 91精品国产综合久久婷婷香蕉| 国产 欧美 在线| 久久都是精品| 欧美日韩国产精品一区二区| 岛国在线视频网站| 亚洲国产成人精品女人久久久| 国产av 一区二区三区| 精品亚洲免费视频| 夜夜爽99久久国产综合精品女不卡 | 97视频在线免费观看| 亚洲av永久无码国产精品久久| 亚洲视频在线观看一区| 欧美激情第一区| 91成人影院| 91久色国产| sm在线观看| 日韩麻豆第一页| 久久久免费高清视频| 久久蜜臀中文字幕| 无码无遮挡又大又爽又黄的视频| 在线成人动漫av| 国产a∨精品一区二区三区不卡| 日本1级在线| 在线精品视频小说1| 国产三级短视频| 狠狠色狠狠色合久久伊人| 蜜桃视频成人在线观看| 亚洲国产视频二区| 97国产一区二区精品久久呦| 四虎精品在线| 欧美性一二三区| 久久精品在线观看视频| 国产一区二区女| 亚洲 欧美 综合 另类 中字| 精品国产一区二区三区成人影院 | а√天堂资源国产精品| 日韩在线观看免费高清| 亚洲av少妇一区二区在线观看| 亚洲va韩国va欧美va| 精品无码在线视频| 人禽交欧美网站| 91网站在线观看免费| 欧美美女啪啪| 国产欧美韩国高清| 五月婷婷视频在线观看| 日韩电影在线观看中文字幕| 一级一级黄色片| 一区二区不卡在线播放 | 91福利视频免费观看| 亚洲精品视频啊美女在线直播| 日韩av高清在线播放| 久久影院一区二区三区| 欧美一区视频在线| 色老头视频在线观看| 亚洲第一男人av| 丰满熟女人妻一区二区三| 亚洲精品ww久久久久久p站| 激情综合丁香五月| 久久99这里只有精品| 国产v片免费观看| 日韩欧美精品一区| 好吊色欧美一区二区三区 | 精品国免费一区二区三区| 成年人视频免费| 亚洲综合av网| 欧美人与禽zoz0善交| 成人永久免费视频| 2025韩国理伦片在线观看| 伊人天天综合| 樱空桃在线播放| 成人影视亚洲图片在线| 国产精品一 二 三| 日韩色性视频| 日韩免费观看高清| 日韩123区| 最新中文字幕亚洲| 欧美一区二区三区少妇| 欧美电影精品一区二区| 色婷婷久久综合中文久久蜜桃av| 五月天亚洲精品| 欧美成人一二三区| 国产精品女同互慰在线看| 欧美丰满少妇人妻精品| 国产成人综合网| 久久精品视频在线观看免费| 久久经典综合| 无罩大乳的熟妇正在播放| 一区二区在线影院| 一区二区三区|亚洲午夜| 欧美日韩123| 欧美福利一区二区三区| 第四色在线一区二区| 99在线视频播放| 精品国产18久久久久久二百| 国产精品专区一| 欧美韩国亚洲| 5566成人精品视频免费| 国产91足控脚交在线观看| 久久综合九色九九| 国产精品99999| 亚洲国产精品久久久久| 国产又粗又猛又爽又黄的| 欧美系列一区二区| 国产91av在线播放| 欧美又粗又大又爽| 国产乡下妇女三片| 欧美色综合网站| 这里只有久久精品视频| 在线亚洲一区二区| 国产精品高清无码| 欧美日本视频在线| 91丨九色丨丰满| 欧美一区二区三区思思人| a天堂视频在线| 欧美军同video69gay| 无码久久精品国产亚洲av影片| 午夜一区二区三区视频| 精品无码一区二区三区电影桃花| 一个色在线综合| 欧美成人aaaaⅴ片在线看| 精品福利免费观看| 国产又爽又黄的视频| 一本一道久久a久久精品| 加勒比在线一区| 欧美日韩国产另类不卡| 国产人妻精品一区二区三区| 日韩午夜激情av| 天堂中文在线官网| 亚洲精品在线不卡| 91在线高清| 欧美成人精品一区二区三区| 日本无删减在线| 91av在线精品| 久久亚洲精品爱爱| 亚洲va电影大全| 久久中文字幕导航| 日韩精品久久久| 91精品1区| 日本欧美黄色片| 日韩成人精品视频| 中文字幕55页| 99国产精品久久久久久久久久| 精品少妇人妻一区二区黑料社区| 中文无字幕一区二区三区| 国产第一页浮力| 婷婷丁香久久五月婷婷| 波多野结衣视频免费观看| 制服丝袜在线91| 深夜福利免费在线观看| 色偷偷av一区二区三区| rebdb初裸写真在线观看| 国产精品观看在线亚洲人成网| 国产专区精品| 久久久久久精| 亚洲老妇激情| 波多野结衣50连登视频| 狠狠色狠狠色合久久伊人| a级一a一级在线观看| 国产精品久久看| 日韩精品一区二区三区国语自制| 欧美性色黄大片手机版| 好男人www在线视频| 中文字幕日韩欧美在线视频| heyzo在线欧美播放| 成人精品久久一区二区三区| 美女扒开腿让男人桶爽久久动漫| 亚洲国产欧美日韩| 亚洲国产日本| 天天操精品视频| 久久亚洲二区三区| 久久久全国免费视频| 欧美午夜不卡在线观看免费| 日韩在线观看视频网站| 久久精品电影一区二区| 欧美日韩免费看片| 国产精品久久久久久久久久久久冷 | 卡通欧美亚洲| 国产精品国产精品| 国产韩国精品一区二区三区| 免费日韩视频在线观看| 成人免费视频一区二区| 日本精品在线免费观看| 欧美性生活影院| 国产在线观看高清视频| 97精品一区二区视频在线观看| 国产一区二区三区视频在线| 亚洲欧洲一区二区| 日韩精品一级二级 | 亚洲成人手机在线| 国产av一区二区三区| 日韩中文字幕国产精品| 亚洲www啪成人一区二区| 免费中文日韩| 国产一区二区你懂的| 国产精品一区二区人妻喷水| 一区二区三区久久久| 91中文字幕在线播放| 中文字幕v亚洲ⅴv天堂| 韩国精品主播一区二区在线观看| 久久婷婷国产综合尤物精品| 亚洲乱码久久| 无码任你躁久久久久久老妇| 亚洲一区二区在线免费看| 国产三级第一页| 久久亚洲春色中文字幕| 91成人在线网站| 异国色恋浪漫潭| 国产做a爰片久久毛片| 亚洲人做受高潮| 欧美精品第一页| 成人影院www在线观看| 亚洲最大av在线| 欧美国产激情| 深夜视频在线观看| 亚洲国产视频在线| 成人午夜免费在线观看| 久久久噜噜噜久久| 精品三级av在线导航| 女人天堂av手机在线| 久久影院视频免费| 自拍偷拍色综合| 日韩在线不卡视频| 综合成人在线| 久久综合九色综合88i| 久久欧美中文字幕| 中文字幕 欧美激情| 精品久久久91| 99久久人爽人人添人人澡 | 亚洲国产日韩欧美在线图片| 超碰在线公开| 亚洲电影一二三区| 国产在线精品免费| 国产主播在线播放| 亚洲男人天堂古典| 色8久久久久| 妞干网视频在线观看| 91美女蜜桃在线| 中文在线观看av| 欧美激情视频免费观看| 任我爽精品视频在线播放| 能看的毛片网站| 亚洲欧洲日本在线| 人妻与黑人一区二区三区| 国产成人久久久精品一区| 外国成人激情视频| 国产 xxxx| 欧美色手机在线观看| 丁香花在线影院| 亚洲精品一区二区毛豆| 国产成人免费视频一区| 青青视频在线免费观看| 久久偷看各类女兵18女厕嘘嘘| 欧美人与动xxxxz0oz| 日本中文字幕精品—区二区| 亚洲国产wwwccc36天堂| 成人77777| 国产伦视频一区二区三区| 日韩精品成人一区二区三区| 免费在线视频一区二区| 亚洲人免费视频| 超碰97久久国产精品牛牛| 99视频在线免费| 午夜视频一区在线观看| 麻豆网在线观看| 欧美日韩三区四区| 风间由美性色一区二区三区| 中文字幕激情视频|