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

首頁 > 編程 > JavaScript > 正文

JS 事件綁定、事件監(jiān)聽、事件委托詳細(xì)介紹

2019-11-20 08:51:12
字體:
供稿:網(wǎng)友

在JavaScript的學(xué)習(xí)中,我們經(jīng)常會遇到JavaScript的事件機制,例如,事件綁定、事件監(jiān)聽、事件委托(事件代理)等。這些名詞是什么意思呢,有什么作用呢?

事件綁定

要想讓 JavaScript 對用戶的操作作出響應(yīng),首先要對 DOM 元素綁定事件處理函數(shù)。所謂事件處理函數(shù),就是處理用戶操作的函數(shù),不同的操作對應(yīng)不同的名稱。

在JavaScript中,有三種常用的綁定事件的方法:

  1. 在DOM元素中直接綁定;
  2. 在JavaScript代碼中綁定;
  3. 綁定事件監(jiān)聽函數(shù)。

在DOM中直接綁定事件

我們可以在DOM元素上綁定onclick、onmouseover、onmouseout、onmousedown、onmouseup、ondblclick、onkeydown、onkeypress、onkeyup等。好多不一一列出了。如果想知道更多事件類型請查看, DOM事件 。

<input type="button" value="click me" onclick="hello()"><script>function hello(){ alert("hello world!");}</script>

在JavaScript代碼中綁定事件

在JavaScript代碼中(即 script 標(biāo)簽內(nèi))綁定事件可以使JavaScript代碼與HTML標(biāo)簽分離,文檔結(jié)構(gòu)清晰,便于管理和開發(fā)。

<input type="button" value="click me" id="btn"><script>document.getElementById("btn").onclick = function(){ alert("hello world!");}</script>

使用事件監(jiān)聽綁定事件

綁定事件的另一種方法是用 addEventListener() 或 attachEvent() 來綁定事件監(jiān)聽函數(shù)。下面詳細(xì)介紹,事件監(jiān)聽。

事件監(jiān)聽

關(guān)于事件監(jiān)聽,W3C規(guī)范中定義了3個事件階段,依次是捕獲階段、目標(biāo)階段、冒泡階段。

起初Netscape制定了JavaScript的一套事件驅(qū)動機制(即事件捕獲)。隨即IE也推出了自己的一套事件驅(qū)動機制(即事件冒泡)。最后W3C規(guī)范了兩種事件機制,分為捕獲階段、目標(biāo)階段、冒泡階段。IE8以前IE一直堅持自己的事件機制(前端人員一直頭痛的兼容性問題),IE9以后IE也支持了W3C規(guī)范。

W3C規(guī)范

語法:

element.addEventListener(event, function, useCapture)

event : (必需)事件名,支持所有 DOM事件 。

function:(必需)指定要事件觸發(fā)時執(zhí)行的函數(shù)。

useCapture:(可選)指定事件是否在捕獲或冒泡階段執(zhí)行。true,捕獲。false,冒泡。默認(rèn)false。

注:IE8以下不支持。

<input type="button" value="click me" id="btn1"><script>document.getElementById("btn1").addEventListener("click",hello);function hello(){ alert("hello world!");}</script>

IE標(biāo)準(zhǔn)

語法:

element.attachEvent(event, function)

event:(必需)事件類型。需加“on“,例如:onclick。

function:(必需)指定要事件觸發(fā)時執(zhí)行的函數(shù)。

<input type="button" value="click me" id="btn2"><script>document.getElementById("btn2").attachEvent("onclick",hello);function hello(){ alert("hello world!");}</script>

事件監(jiān)聽的優(yōu)點

1、可以綁定多個事件。

<input type="button" value="click me" id="btn3"><script>var btn3 = document.getElementById("btn3");btn3.onclick = function(){ alert("hello 1"); //不執(zhí)行}btn3.onclick = function(){ alert("hello 2"); //執(zhí)行}</script>

常規(guī)的事件綁定只執(zhí)行最后綁定的事件。

<input type="button" value="click me" id="btn4"><script>var btn4 = document.getElementById("btn4");btn4.addEventListener("click",hello1);btn4.addEventListener("click",hello2);function hello1(){ alert("hello 1");}function hello2(){ alert("hello 2");}</script>

兩個事件都執(zhí)行了。

2、可以解除相應(yīng)的綁定

<input type="button" value="click me" id="btn5"><script>var btn5 = document.getElementById("btn5");btn5.addEventListener("click",hello1);//執(zhí)行了btn5.addEventListener("click",hello2);//不執(zhí)行btn5.removeEventListener("click",hello2);function hello1(){ alert("hello 1");}function hello2(){ alert("hello 2");}</script>

封裝事件監(jiān)聽

<input type="button" value="click me" id="btn5">//綁定監(jiān)聽事件function addEventHandler(target,type,fn){ if(target.addEventListener){ target.addEventListener(type,fn); }else{ target.attachEvent("on"+type,fn); }}//移除監(jiān)聽事件function removeEventHandler(target,type,fn){ if(target.removeEventListener){ target.removeEventListener(type,fn); }else{ target.detachEvent("on"+type,fn); }}//測試var btn5 = document.getElementById("btn5");addEventHandler(btn5,"click",hello1);//添加事件hello1addEventHandler(btn5,"click",hello2);//添加事件hello2removeEventHandler(btn5,"click",hello1);//移除事件hello1

事件委托

事件委托就是利用冒泡的原理,把事件加到父元素或祖先元素上,觸發(fā)執(zhí)行效果。

<input type="button" value="click me" id="btn6">var btn6 = document.getElementById("btn6");document.onclick = function(event){ event = event || window.event; var target = event.target || event.srcElement; if(target == btn6){ alert(btn5.value); }}

上面只是個例子,代碼盡可能的簡化了。在實際的代碼中 我們可能用到j(luò)Query的live()、delegate()、bind()、on()等。

事件委托優(yōu)點

1、提高JavaScript性能。事件委托可以顯著的提高事件的處理速度,減少內(nèi)存的占用。 實例分析JavaScript中的事件委托和事件綁定 ,這篇文章寫得還不錯。

傳統(tǒng)寫法

<ul id="list"> <li id="item1" >item1</li> <li id="item2" >item2</li> <li id="item3" >item3</li></ul><script>var item1 = document.getElementById("item1");var item2 = document.getElementById("item2");var item3 = document.getElementById("item3");item1.onclick = function(){ alert("hello item1");}item2.onclick = function(){ alert("hello item2");}item3.onclick = function(){ alert("hello item3");}</script>

事件委托

<ul id="list"> <li id="item1" >item1</li> <li id="item2" >item2</li> <li id="item3" >item3</li></ul><script>var item1 = document.getElementById("item1");var item2 = document.getElementById("item2");var item3 = document.getElementById("item3");document.addEventListener("click",function(event){ var target = event.target; if(target == item1){ alert("hello item1"); }else if(target == item2){ alert("hello item2"); }else if(target == item3){ alert("hello item3"); }})</script>

2、動態(tài)的添加DOM元素,不需要因為元素的改動而修改事件綁定。

傳統(tǒng)寫法

<ul id="list"> <li id="item1" >item1</li> <li id="item2" >item2</li> <li id="item3" >item3</li></ul><script>var list = document.getElementById("list");var item = list.getElementsByTagName("li");for(var i=0;i<item.length;i++){ (function(i){ item[i].onclick = function(){ alert(item[i].innerHTML); } })(i)}var node=document.createElement("li");var textnode=document.createTextNode("item4");node.appendChild(textnode);list.appendChild(node);</script>

點擊item1到item3都有事件響應(yīng),但是點擊item4時,沒有事件響應(yīng)。說明傳統(tǒng)的事件綁定無法對動態(tài)添加的元素而動態(tài)的添加事件。

事件委托

<ul id="list"> <li id="item1" >item1</li> <li id="item2" >item2</li> <li id="item3" >item3</li></ul><script>var list = document.getElementById("list");document.addEventListener("click",function(event){ var target = event.target; if(target.nodeName == "LI"){ alert(target.innerHTML); }})var node=document.createElement("li");var textnode=document.createTextNode("item4");node.appendChild(textnode);list.appendChild(node);</script>

當(dāng)點擊item4時,item4有事件響應(yīng)。說明事件委托可以為新添加的DOM元素動態(tài)的添加事件。

 通過此文,希望能幫助到大家,謝謝大家對本站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鹤峰县| 通辽市| 烟台市| 南开区| 延津县| 拉孜县| 临城县| 永州市| 乐亭县| 浦江县| 黑龙江省| 深泽县| 土默特左旗| 荃湾区| 石狮市| 田林县| 吉木乃县| 营口市| 波密县| 东源县| 安远县| 罗平县| 高密市| 达尔| 六枝特区| 梅河口市| 贡觉县| 定襄县| 绥中县| 克山县| 乌恰县| 搜索| 英吉沙县| 志丹县| 兰西县| 保康县| 汉阴县| 黎平县| 赞皇县| 巴彦淖尔市| 驻马店市|