国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

原生js實現trigger方法示例代碼

2019-11-19 11:29:56
字體:
來源:轉載
供稿:網友

前言

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

首先需要將事件綁定至指定DOM節點上

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

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

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

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

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

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

1.為Element 增加trigger方法

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

2.為 NodeList 增加 trigger 方法

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

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

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

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

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

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 招远市| 陈巴尔虎旗| 南通市| 昭苏县| 聂拉木县| 荥阳市| 图木舒克市| 噶尔县| 德格县| 平塘县| 沾益县| 华宁县| 图们市| 昌黎县| 光泽县| 勃利县| 长汀县| 玛纳斯县| 特克斯县| 田东县| 会昌县| 托里县| 襄垣县| 黎城县| 祁门县| 忻州市| 师宗县| 刚察县| 航空| 芮城县| 耿马| 玉田县| 加查县| 长顺县| 新民市| 都匀市| 湾仔区| 祁连县| 巫溪县| 昌宁县| 商河县|