91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用JavaScript怎么實現一個trigger方法

發布時間:2021-04-14 17:27:40 來源:億速云 閱讀:397 作者:Leah 欄目:web開發

這篇文章給大家介紹使用JavaScript怎么實現一個trigger方法,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

首先需要將事件綁定至指定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'); // 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() 獲取的節點, 卻并未存在 .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

關于使用JavaScript怎么實現一個trigger方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

张掖市| 陆河县| 香港| 北票市| 广德县| 涿鹿县| 乐东| 武夷山市| 江孜县| 鹿邑县| 米脂县| 临安市| 油尖旺区| 抚州市| 贵港市| 永年县| 博兴县| 巴中市| 密云县| 大兴区| 正蓝旗| 霍邱县| 双辽市| 沛县| 吉林市| 巴林左旗| 沽源县| 来安县| 洮南市| 丰县| 隆尧县| 延长县| 江陵县| 普定县| 灵川县| 绥中县| 盈江县| 巴林右旗| 玛曲县| 厦门市| 攀枝花市|