javascript相關事件的幾個概念

來源:互聯網
上載者:User

javascript相關事件的幾個概念

   對於事件來講,首先,我們需要瞭解這樣幾個概念:事件;事件處理常式;事件類型;事件流;事件冒泡;事件捕獲;事件對象;事件方面的效能最佳化(事件委託、移除事件處理常式);常見的瀏覽器安全色問題。

  用戶端javascript程式採用了非同步事件驅動編程模型。

  相關事件的幾個概念:

  事件類型(event type):用來說明發生什麼類型事件的字串;

  事件目標(event target):發生事件的對象;

  事件處理常式(event handler):處理或響應事件的函數;

  事件對象(event object):與特定事件相關且包含有關該事件詳細資料的對象;

  事件傳播(event propagation):瀏覽器決定哪個對象出發其事件處理常式的過程;

  註冊事件處理常式:

  1、設定javascript對象屬性;

  2、設定html標籤屬性

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

  ?

1

2

3

4

5

6

7

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、發生在目標處理函數之前,稱為‘捕獲'階段;

  2、對象本身的處理事件的調用;

  3、事件的冒泡階段;

  在javascript中,可以為某個元素指定事件,指定的方式有以下三種:

  1、在html中,使用onclick屬性

  2、在javascript中,使用onclick屬性

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

  三種方法的比較

  (1)在第二、三種方法中,可以向函數傳入一個event對象,並讀取其相應屬性,而方法一不可以。

  (2)首選第二、三種,第一種不利於將內容與事件分離,也不能使用event對象的相關內容。

  一些文法細節

  (1)在第一種方法中,onclick大小寫無關,但在第二種方法中,必須使用小寫。因為HMTL對大小寫不敏感,而JS則會區分大小寫。

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

  (3)第一種方法需要括弧,第二、三種不需要。

  ?

1

2

3

onclick="clickHandler()"

document.getElementById("jsOnClick").onclick = clickHandler2;

document.getElementById("addEventListener").addEventListener("click", clickHandler2);

  完整代碼:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

<!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>

  以上所述就是本文的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.