亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JavaScript中的模擬事件和自定義事件實例分析

2024-05-06 16:46:04
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript中的模擬事件和自定義事件。分享給大家供大家參考,具體如下:

前面介紹了JavaScript中為事件指定處理程序的五種方式JavaScript的事件對象event。

下面介紹JavaScript中的模擬事件和自定義事件。

1、DOM中的事件模擬

1) DOM中的事件模擬有以下3個步驟:

步驟1:創建事件對象event

可以在document對象上使用createEvent()方法創建event對象,此方法接收一個參數,即要創建的事件類型的字符串。在DOM2級中這些字符串都使用英文復數形式,而在DOM3級中都變成了單數。這個字符串可以是以下幾個字符串之一:

① UIEvents:一般化的UI事件,鼠標事件和鍵盤事件都繼承自UI事件,DOM3級中是UIEvent;

② MouseEvents:一般化的鼠標事件,DOM3級中是MouseEvent;

③ MutationEvents:一般化的DOM變動事件,DOM3級中是MutationEvent;

④ HTMLEvents:一般化的HTML事件,沒有對應的DOM3級事件,被分散到 其他類別中。

步驟2:初始化事件對象

使用與事件有關的信息對其進行初始化,每種類型的event對象都有一個特殊的方法,為它傳入適當的數據就可以初始化該event對象,不同類型的方法的名字也不相同,具體要取決于createEvent()中使用的參數。

步驟3:觸發事件

使用dispatch()方法,此方法接收一個參數,即要觸發事件的event對象。

2) 模擬鼠標事件:

使用createEvent()方法創建event對象,傳入字符串"MouseEvents",返回的對象有一個名為initMouseEvent()方法,用于指定與該鼠標事件有關的信息。

模擬按鈕的單擊事件:

var btn = document.getElementsByTagNames("button")[0];var event = document.createEvent("MouseEvents");event.initMouseEvent("click", true, true, document.defaultView, 0, 0, 0, 0, 0, false, false, false, 0, null);btn.dispatchEvent(event);

3) 模擬鍵盤事件:

使用createEvent()方法創建event對象,傳入字符串"KeyboardEvent",返回的對象有一個名為initKeyboardEvent()方法。

DOM2級事件并沒有專門規定鍵盤事件,后來的DOM3級事件才正式將其作為一種事件給出規定。IE9是目前唯一支持DOM3級鍵盤事件的瀏覽器,但其他瀏覽器也可以模擬鍵盤事件。

在使用createEvent()方法之前,需要先檢測瀏覽器是否支持DOM3級事件。

模擬按住Shift的同時又按下A鍵:

var text = document.getElementsByTagNames("input")[0];if (document.implementation.hasFeature("KeyboardEvents", 3.0) {  var event = document.createEvent("KeyboardEvent");  event.initKeyboardEvent("keydown", true, true, document.defaultView, "a", 0, "Shift", 0);}text.dispatchEvent(event);

4) 模擬其他事件:

① 模擬變動事件:

使用createEvent()方法創建event對象,傳入字符串"MutationEvents",返回的對象有一個名為initMutationEvent()的方法。

var event = document.createEvent("MutationEvents");event.initMutationEvent("DOMNodeInserted", true, false, someNode, "", "", "", 0);target.dispatchEvent(event);

② 模擬HTML事件:

使用createEvent()方法創建event對象,傳入字符串"HTMLEvents",返回的對象有一個名為initMutationEvent()的方法。

var event = document.createEvent("HTMLEvents");event.initEvent("focus", true, false);target.dispatchEvent(event);

5) 自定義DOM事件:

DOM3級還定義了自定義事件。自定義事件不是由DOM原生觸發的,目的是讓開發人員創建自己的事件。

創建自定義事件,可以使用createEvent("CustomEvent")方法,返回的對象有一個名為initCustomEvent()的方法,接收如下4個參數:

type(字符串):事件類型;

bubbles(布爾值):時間是否應該冒泡;

cancelable(布爾值):表示事件是否可以取消;

detail(對象):任意值,保存在event對象的detail屬性中。

var div = document.getElementsByTagNames("div")[0];EventUtil.addHandler(div, "myEvent", function(event) {  alert("div:" + event.detail);});EventUtil.addHandler(document, "myEvent", function(event) {  alert("document:" + event.detail);});if (document.implementation.hasFeature("CustomEvents", 3.0) {  var event = document.createEvent("CustomEvent");  event.initCustomEvent("myEvent", true, false, "Hello world");}div.dispatchEvent(event);

單擊div會輸出:

div:Hello world
document:Hello world

單擊document會輸出:

document:Hello world

2、IE中的事件模擬

IE中的事件模擬有以下3個步驟:

① 使用document.createEventObject()方法在IE中創建event對象,與DOM不同的是,此方法不接受參數,結果會返回一個通用的event對象。

② 為event對象手動添加所有必要的信息,沒有方法來輔助添加。

③ 在目標上使用fireEvent()方法,此方法接收兩個參數:事件處理程序的名稱和event對象。在調用fireEvent()方法時,會自動為event對象添加srcElementtype屬性,其他屬性則必須手動添加。

在IE中,模擬任何事件都采用相同的模式。

模擬click事件:

var btn = document.getElementsByTagNames("button")[0];var event = document.createEventObject();event.screenX = 100;event.screenY = 0;event.clientX = 0;event.clientY = 0;event.strlKey = false;event.altKey = false;event.shiftKey = false;Event.button = 0;btn.fireEvent("onclick", event);

模擬keypress事件:

var text = document.getElementsByTagNames("input")[0];var event = document.createEventObject();event.strlKey = false;event.altKey = false;event.shiftKey = false;Event.keyCode = 65;btn.fireEvent("onkeypress", event);

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美va欧美va香蕉在| 97国产在线观看| 欧美有码在线观看视频| 成人福利在线视频| 日韩免费观看高清| 日韩亚洲精品电影| 欧美制服第一页| 一区二区三区美女xx视频| 亚洲综合精品伊人久久| 在线视频欧美日韩精品| 欧美成人中文字幕| 国产精品久久久久久久一区探花| 国产日韩av在线播放| 久久国产精品电影| 91av成人在线| 欧美成人高清视频| 国产精品第8页| 亚洲人成在线电影| 91精品视频免费观看| 精品亚洲一区二区三区四区五区| 日本一区二区三区在线播放| 欧美激情一区二区三级高清视频| 欧美影院久久久| 国产精品视频免费在线观看| 美女扒开尿口让男人操亚洲视频网站| 神马久久桃色视频| 久久资源免费视频| 国产精品va在线播放我和闺蜜| 北条麻妃久久精品| 成人a在线观看| 亚洲日本欧美日韩高观看| 午夜精品99久久免费| 欧美性黄网官网| 色综合影院在线| 国产精品久久久久久久午夜| 国产精品免费在线免费| 91老司机精品视频| 日韩禁在线播放| 精品美女国产在线| 国产一区二区动漫| 欧美精品日韩www.p站| 国产亚洲在线播放| 亚洲精品第一页| 精品视频在线播放免| 日韩中文字幕视频在线观看| 欧美理论片在线观看| 国产精品美腿一区在线看| 97久久久免费福利网址| 欧美精品精品精品精品免费| 欧美另类69精品久久久久9999| 精品久久久久久久久久久久久久| 日韩欧美国产骚| 欧美视频中文在线看| 欧美视频裸体精品| 狠狠躁夜夜躁人人爽超碰91| 亚洲欧洲成视频免费观看| 日韩av综合网| 永久免费看mv网站入口亚洲| 丰满岳妇乱一区二区三区| 欧美黑人巨大xxx极品| 91视频国产精品| 国产亚洲aⅴaaaaaa毛片| 亚洲韩国欧洲国产日产av| 亚洲欧美国产视频| 国产精品日日摸夜夜添夜夜av| 亚洲国产精品va在线观看黑人| 中文字幕亚洲激情| 91成人福利在线| 国产精品爽黄69天堂a| 国产美女精品免费电影| 久久91超碰青草是什么| 国产欧美精品日韩| 在线亚洲国产精品网| 色偷偷888欧美精品久久久| 久久久伊人日本| 亚洲精品国精品久久99热一| 97国产在线观看| 亚洲成成品网站| 亚洲国产97在线精品一区| 欧美在线精品免播放器视频| 一本色道久久综合狠狠躁篇的优点| 欧美激情国产日韩精品一区18| 成人激情免费在线| 欧美成人国产va精品日本一级| 日韩av在线高清| 欧美成人中文字幕| 亚洲乱码一区二区| 欧美电影免费观看| 亚洲深夜福利在线| 日韩av免费观影| 精品亚洲aⅴ在线观看| 韩国三级电影久久久久久| 欧美日韩在线视频观看| 国产日韩精品在线播放| 欧美极品少妇xxxxⅹ喷水| 欧美色播在线播放| 欧美黑人一级爽快片淫片高清| 亚洲iv一区二区三区| 久久99亚洲热视| 欧美激情精品久久久久久| 日韩在线观看精品| 欧美成人高清视频| 国内外成人免费激情在线视频| 日韩国产在线播放| 久久免费高清视频| 亚洲国产精品成人精品| 日本中文字幕不卡免费| 国产美女扒开尿口久久久| 国产极品精品在线观看| 日本成人在线视频网址| 久久久久久久激情视频| 日韩精品在线免费观看视频| 精品成人乱色一区二区| 国产精品美女在线观看| 国产精品久久久久久亚洲影视| 中文字幕av一区| 国产精品白嫩美女在线观看| 欧美中文字幕第一页| 色香阁99久久精品久久久| 久久精品国产一区二区三区| 亚洲激情在线观看视频免费| 亚洲影院色无极综合| 秋霞av国产精品一区| 亚洲va久久久噜噜噜久久天堂| 日本高清不卡在线| 日本成人在线视频网址| 国产成人一区二| 日韩欧美在线中文字幕| 亚洲网站在线观看| 欧美日韩国产va另类| 国产精品一区二区久久国产| 日韩性生活视频| 亚洲片在线观看| 日韩高清人体午夜| 国产精品av网站| 九九热这里只有精品免费看| 欧美精品福利视频| 亚洲福利在线播放| 国产精品一区二区久久久| 久久久久久久久久国产精品| 国产精品自产拍高潮在线观看| 欧美日韩中国免费专区在线看| 欧美一区二区色| 国产成人一区二区三区| 欧美午夜精品伦理| 97精品在线观看| 欧美国产在线视频| 日韩第一页在线| 国产经典一区二区| 色先锋资源久久综合5566| 国产美女精品视频免费观看| 精品视频9999| 亚洲成人av在线播放| 中文日韩电影网站| 欧美大片va欧美在线播放| 国产精选久久久久久| 国产精品免费久久久久久| 欧美一级视频一区二区| 国产日韩欧美中文| 97视频免费观看| 国产精品高清网站| 色久欧美在线视频观看| 国产精品一区av| 国产精品免费在线免费|