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

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

javascript相關(guān)事件的幾個(gè)概念

2024-05-06 16:20:40
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

對(duì)于事件來(lái)講,首先,我們需要了解這樣幾個(gè)概念:事件;事件處理程序;事件類型;事件流;事件冒泡;事件捕獲;事件對(duì)象;事件方面的性能優(yōu)化(事件委托、移除事件處理程序);常見的瀏覽器兼容問題。

客戶端javascript程序采用了異步事件驅(qū)動(dòng)編程模型。

相關(guān)事件的幾個(gè)概念:

事件類型(event type):

用來(lái)說明發(fā)生什么類型事件的字符串;

事件目標(biāo)(event target):

發(fā)生事件的對(duì)象;

事件處理程序(event handler):

處理或響應(yīng)事件的函數(shù);

事件對(duì)象(event object):

與特定事件相關(guān)且包含有關(guān)該事件詳細(xì)信息的對(duì)象;

事件傳播(event propagation):

瀏覽器決定哪個(gè)對(duì)象出發(fā)其事件處理程序的過程;

注冊(cè)事件處理程序:

1、設(shè)置javascript對(duì)象屬性;

2、設(shè)置html標(biāo)簽屬性

3、addEventListener或attachEvent(后者為IE的)

 

 
  1. function addEvent(target,type,handler){ 
  2. if(target.addEventListener){ 
  3. target.addEventListener(type,handler,false); 
  4. }else
  5. target.attachEvent("on"+type,function(event){return handler.call(target,event)}); 

事件傳播的三個(gè)階段:

1、發(fā)生在目標(biāo)處理函數(shù)之前,稱為‘捕獲'階段;

2、對(duì)象本身的處理事件的調(diào)用;

3、事件的冒泡階段;

為某個(gè)元素指定事件

在javascript中,可以,有以下三種:

1、在html中,使用onclick屬性

2、在javascript中,使用onclick屬性

3、在javascipt中,使用addEvenListener()方法

三種方法的比較

(1)在第二、三種方法中,可以向函數(shù)傳入一個(gè)event對(duì)象,并讀取其相應(yīng)屬性,而方法一不可以。

(2)首選第二、三種,第一種不利于將內(nèi)容與事件分離,也不能使用event對(duì)象的相關(guān)內(nèi)容。

一些語(yǔ)法細(xì)節(jié)

(1)在第一種方法中,onclick大小寫無(wú)關(guān),但在第二種方法中,必須使用小寫。因?yàn)镠MTL對(duì)大小寫不敏感,而JS則會(huì)區(qū)分大小寫。

(2)在第二、三種方法中,指定函數(shù)名時(shí)沒有雙引號(hào),而第一種作為一個(gè)HTML屬性,需要雙引號(hào)。

(3)第一種方法需要括號(hào),第二、三種不需要。

 

 
  1. onclick="clickHandler()" 
  2. document.getElementById("jsOnClick").onclick = clickHandler2;  
  3. document.getElementById("addEventListener").addEventListener("click", clickHandler2); 

完整代碼:

 

 
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4. <meta charset="UTF-8">  
  5. <title>Even Deom</title>  
  6.  
  7. </head>  
  8. <body>  
  9. <button id="htmlOnClick" onclick="clickHandler()">htmlOnClick</button>  
  10. <button id="jsOnClick">jsOnClick</button>  
  11. <button id="addEventListener">addEventListener</button>  
  12.  
  13. <script defer>  
  14. function clickHandler() {  
  15. alert("onclick attribute in html");  
  16. }  
  17. function clickHandler2(e) {  
  18. alert(e.target.innerHTML);  
  19. }  
  20. document.getElementById("jsOnClick").onclick = clickHandler2;  
  21. document.getElementById("addEventListener").addEventListener("click",  
  22. clickHandler2);  
  23. </script>  
  24. </body>  
  25. </html>  

以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 高雄市| 永城市| 灵寿县| 石屏县| 南投市| 峨边| 东兰县| 威海市| 巴彦县| 神木县| 宁强县| 通许县| 株洲市| 六枝特区| 南昌县| 嘉峪关市| 朝阳区| 滦平县| 页游| 乳源| 民勤县| 临澧县| 东乡| 开江县| 鄂托克前旗| 郴州市| 布尔津县| 紫阳县| 广平县| 武夷山市| 尉犁县| 寿宁县| 菏泽市| 武宣县| 鄢陵县| 曲靖市| 定州市| 上栗县| 桃江县| 孝义市| 通城县|