欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年07月27日 10:55:10   作者:筱葭  
這篇文章主要介紹了JavaScript中的模擬事件和自定義事件,結(jié)合實例形式分析了JavaScript模擬事件和自定義事件相關(guān)操作步驟、實現(xiàn)技巧與注意事項,需要的朋友可以參考下

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

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

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

1、DOM中的事件模擬

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

步驟1:創(chuàng)建事件對象event

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

UIEvents:一般化的UI事件,鼠標(biāo)事件和鍵盤事件都繼承自UI事件,DOM3級中是UIEvent

MouseEvents:一般化的鼠標(biāo)事件,DOM3級中是MouseEvent

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

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

步驟2:初始化事件對象

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

步驟3:觸發(fā)事件

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

2) 模擬鼠標(biāo)事件:

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

模擬按鈕的單擊事件:

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()方法創(chuàng)建event對象,傳入字符串"KeyboardEvent",返回的對象有一個名為initKeyboardEvent()方法。

DOM2級事件并沒有專門規(guī)定鍵盤事件,后來的DOM3級事件才正式將其作為一種事件給出規(guī)定。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()方法創(chuàng)建event對象,傳入字符串"MutationEvents",返回的對象有一個名為initMutationEvent()的方法。

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

② 模擬HTML事件:

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

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

5) 自定義DOM事件:

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

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

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

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

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中創(chuàng)建event對象,與DOM不同的是,此方法不接受參數(shù),結(jié)果會返回一個通用的event對象。

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

③ 在目標(biāo)上使用fireEvent()方法,此方法接收兩個參數(shù):事件處理程序的名稱和event對象。在調(diào)用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);

PS:關(guān)于javascript事件說明可參考本站javascript事件與功能說明大全http://tools.jb51.net/table/javascript_event

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript頁面元素操作技巧總結(jié)》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)

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

相關(guān)文章

  • tensorflow中的梯度求解及梯度裁剪操作

    tensorflow中的梯度求解及梯度裁剪操作

    這篇文章主要介紹了tensorflow中的梯度求解及梯度裁剪操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python中調(diào)用其他程序的方式詳解

    Python中調(diào)用其他程序的方式詳解

    這篇文章主要介紹了Python中調(diào)用其他程序的方式詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • 詳解Python 多線程 Timer定時器/延遲執(zhí)行、Event事件

    詳解Python 多線程 Timer定時器/延遲執(zhí)行、Event事件

    這篇文章主要介紹了Python 多線程 Timer定時器/延遲執(zhí)行、Event事件的相關(guān)知識,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • Python-typing: 類型標(biāo)注與支持 Any類型詳解

    Python-typing: 類型標(biāo)注與支持 Any類型詳解

    這篇文章主要介紹了Python-typing: 類型標(biāo)注與支持 Any類型詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • 利用Python計算圓周率π的實例代碼

    利用Python計算圓周率π的實例代碼

    圓周率沒有精確的計算公式,所以只能用近似的方式計算它的近似值。這篇文章主要介紹了利用Python計算圓周率π的相關(guān)資料,需要的朋友可以參考下
    2021-05-05
  • Django中日期處理注意事項與自定義時間格式轉(zhuǎn)換詳解

    Django中日期處理注意事項與自定義時間格式轉(zhuǎn)換詳解

    這篇文章主要給大家介紹了關(guān)于Django中日期處理注意事項與自定義時間格式轉(zhuǎn)換的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-08-08
  • Python的對象傳遞與Copy函數(shù)使用詳解

    Python的對象傳遞與Copy函數(shù)使用詳解

    今天小編就為大家分享一篇Python的對象傳遞與Copy函數(shù)使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 淺談python新式類和舊式類區(qū)別

    淺談python新式類和舊式類區(qū)別

    python的新式類是2.2版本引進來的,我們可以將之前的類叫做經(jīng)典類或者舊式類。這篇文章主要介紹了淺談python新式類和舊式類區(qū)別,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • python3使用pandas獲取股票數(shù)據(jù)的方法

    python3使用pandas獲取股票數(shù)據(jù)的方法

    今天小編就為大家分享一篇python3使用pandas獲取股票數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • Python中NumPy的數(shù)組重塑

    Python中NumPy的數(shù)組重塑

    這篇文章主要介紹了Python中NumPy的數(shù)組重塑,Numpy是Python科學(xué)計算庫,用于快速處理任意維度的數(shù)組,NumPy使用c語言寫的,底部解除了GIL,其對數(shù)組的操作速度不在受python解釋器限制<BR>
    2023-07-07

最新評論