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

原生js實現(xiàn)trigger方法示例代碼

 更新時間:2019年05月22日 11:10:20   作者:拭目以待  
這篇文章主要給大家介紹了關于利用原生js實現(xiàn)trigger方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用js具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

事件綁定成功之后,事件的執(zhí)行函數(shù)就如同待字閨中的小姑娘。除了由坐在電腦前的大叔們用鍵盤、鼠標等硬件行為觸發(fā)外,需要在代碼中直接調用又該如何實現(xiàn)?

首先需要將事件綁定至指定DOM節(jié)點上

// 在一個節(jié)點上綁定一個事件
let test = document.createElement('div');
test.id = 'test';
test.innerHTML = '測試事件';
document.body.appendChild(test);
test.addEventListener('mousedown', function(){
  console.log('hello jTool');
}, false)

事件綁定成功之后,事件的執(zhí)行函數(shù)就如同待字閨中的小姑娘。除了由坐在電腦前的大叔們用鍵盤、鼠標等硬件行為觸發(fā)外,需要在代碼中直接調用又該如何實現(xiàn)?在 jQuery 中的事件類中包含一個trigger方法, 我之前寫的類庫 jTool 中同樣也實現(xiàn)了該方法, 下面就以 jTool 的視角來說明下 trigger 如何實現(xiàn)。

綁定事件時使用 DOM 對象的 .addEventListener() 方法, 而實現(xiàn) trigger 則是使用 DOM 對像的 .dispatchEvent() 方法。

.dispatchEvent() 需要以參數(shù)形式傳入被派發(fā)的事件對象, 該事件對象可以通過 javascript 的全局構造函數(shù) Event。

// 觸發(fā)事件
var myEvent = new Event('mousedown');
test.dispatchEvent(myEvent); // => true

接下來實現(xiàn)在獲取的節(jié)點上直接調用 .trigger() 方法

1.為Element 增加trigger方法

Element.prototype.trigger = function(eventName){
  this.dispatchEvent(new Event(eventName));
}
let target = document.querySelector('#test'); // Element
target.trigger('mousedown'); // => 'hello jTool'

2.為 NodeList 增加 trigger 方法

target = document.querySelectorAll('#test'); // NodeList
target.trigger('mousedown'); // => Uncaught TypeError: target.trigger is not a function

如上所示 .querySelectorAll() 獲取的節(jié)點, 卻并未存在 .trigger() 方法, 這是由于通過 .querySelectorAll() 獲取到的是 NodeList 實例而非 Element。

NodeList.prototype.trigger = function(eventName){
  [].forEach.call(this, function(item, index){
    item.dispatchEvent(new Event(eventName));
  });
}
target = document.querySelectorAll('#test'); // NodeList
target.trigger('mousedown'); // => hello jTool

而以上的方法僅限于直接綁定至 DOM 的事件,預綁定的事件,無法通過 new Event().dispatchEvent() 來執(zhí)行, 且需要其它方法協(xié)同處理。

以上代碼是在進行jtool類庫編碼時實踐出來的方式,歡迎star

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

最新評論