javascript相關事件的幾個概念
客戶端javascript程序采用了異步事件驅(qū)動編程模型。
相關事件的幾個概念:
事件類型(event type):用來說明發(fā)生什么類型事件的字符串;
事件目標(event target):發(fā)生事件的對象;
事件處理程序(event handler):處理或響應事件的函數(shù);
事件對象(event object):與特定事件相關且包含有關該事件詳細信息的對象;
事件傳播(event propagation):瀏覽器決定哪個對象出發(fā)其事件處理程序的過程;
注冊事件處理程序:
1、設置javascript對象屬性;
2、設置html標簽屬性
3、addEventListener或attachEvent(后者為IE的)
function addEvent(target,type,handler){ if(target.addEventListener){ target.addEventListener(type,handler,false); }else{ target.attachEvent("on"+type,function(event){return handler.call(target,event)}); } }
事件傳播的三個階段:
1、發(fā)生在目標處理函數(shù)之前,稱為‘捕獲'階段;
2、對象本身的處理事件的調(diào)用;
3、事件的冒泡階段;
在javascript中,可以為某個元素指定事件,指定的方式有以下三種:
1、在html中,使用onclick屬性
2、在javascript中,使用onclick屬性
3、在javascipt中,使用addEvenListener()方法
三種方法的比較
(1)在第二、三種方法中,可以向函數(shù)傳入一個event對象,并讀取其相應屬性,而方法一不可以。
(2)首選第二、三種,第一種不利于將內(nèi)容與事件分離,也不能使用event對象的相關內(nèi)容。
一些語法細節(jié)
(1)在第一種方法中,onclick大小寫無關,但在第二種方法中,必須使用小寫。因為HMTL對大小寫不敏感,而JS則會區(qū)分大小寫。
(2)在第二、三種方法中,指定函數(shù)名時沒有雙引號,而第一種作為一個HTML屬性,需要雙引號。
(3)第一種方法需要括號,第二、三種不需要。
onclick="clickHandler()" document.getElementById("jsOnClick").onclick = clickHandler2; document.getElementById("addEventListener").addEventListener("click", clickHandler2);
完整代碼:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Even Deom</title> </head> <body> <button id="htmlOnClick" onclick="clickHandler()">htmlOnClick</button> <button id="jsOnClick">jsOnClick</button> <button id="addEventListener">addEventListener</button> <script defer> function clickHandler() { alert("onclick attribute in html"); } function clickHandler2(e) { alert(e.target.innerHTML); } document.getElementById("jsOnClick").onclick = clickHandler2; document.getElementById("addEventListener").addEventListener("click", clickHandler2); </script> </body> </html>
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
- JavaScript基本概念初級講解論壇貼的學習記錄
- javascript,jquery閉包概念分析
- JavaScript內(nèi)核之基本概念
- javascript學習筆記(二) js一些基本概念
- JavaScript回調(diào)(callback)函數(shù)概念自我理解及示例
- JavaScript的作用域和塊級作用域概念理解
- JavaScript 基本概念
- javascript中幾個容易混淆的概念總結(jié)
- 通過實例理解javascript中沒有函數(shù)重載的概念
- 深入理解JavaScript編程中的原型概念
- 深入剖析JavaScript編程中的對象概念
- 帶領大家學習javascript基礎篇(一)之基本概念
相關文章
JavaScript數(shù)據(jù)結(jié)構與算法之二叉樹添加/刪除節(jié)點操作示例
這篇文章主要介紹了JavaScript數(shù)據(jù)結(jié)構與算法之二叉樹添加/刪除節(jié)點操作,涉及javascript二叉樹的定義、節(jié)點添加、刪除、遍歷等相關操作技巧,需要的朋友可以參考下2019-03-03JavaScript中使用replace結(jié)合正則實現(xiàn)replaceAll的效果
JavaScript?中使用?replace?達到?replaceAll的效果,其實就用利用的正則的全局替換。2010-06-06