jQuery學(xué)習(xí)4 瀏覽器的事件模型
更新時間:2010年02月07日 10:11:46 作者:
首先要知道DOM的兩級模式:DOM0級和DOM2級 在DOM0級事件處理程序是通過把函數(shù)實例的引用指派到DOM元素的屬性而聲明的。
首先要知道DOM的兩級模式:DOM0級和DOM2級
在DOM0級事件處理程序是通過把函數(shù)實例的引用指派到DOM元素的屬性而聲明的。
聲明DOM第0級事件處理程序
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>DOM Level 0 Events Example</title>
<script type="text/javascript" src="../scripts/jquery-1.2.1.js">
</script>
<script type="text/javascript">
$(function(){
$('#vstar')[0].onmouseover = function(event) {
say('Whee!');
}
});
function say(text) {
$('#console').append('<div>'+new Date()+' '+text+'</div>');
}
</script>
</head>
<body>
<img id="vstar" src="vstar.jpg" onclick="say('Vroom vroom!')"/>
<div id="console"></div>
</body>
</html>
事件冒泡:在目標(biāo)元素獲得機(jī)會處理事件之后,事件模型檢查目標(biāo)元素的父元素,看是否為同類型事件建立了處理程序。如果是,則也調(diào)用父元素的處理程序。再檢查其父元素,直至檢查到DOM樹的頂部,這個過程稱之為事件冒泡。
事件傳播從起點到DOM樹的頂部
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html id="greatgreatgrandpa">
<head>
<title>DOM Level 0 Bubbling Example</title>
<script type="text/javascript" src="../scripts/jquery-1.2.1.js">
</script>
<script type="text/javascript">
$(function(){
$('*').each(function(){
var current = this;
this.onclick = function(event) {
if (!event) event = window.event;
var target = (event.target) ?
event.target : event.srcElement;
say('For ' + current.tagName + '#'+ current.id +
' target is ' + target.id);
}
});
});
function say(text) {
$('#console').append('<div>'+text+'</div>');
}
</script>
</head>
<body id="greatgrandpa">
<div id="grandpa">
<div id="pops">
<img id="vstar" src="vstar.jpg"/>
</div>
</div>
<div id="console"></div>
</body>
</html>
DOM第2級事件模型
DOM第0級的缺點是,屬性被用于存儲作為事件處理程序的函數(shù)的引用,所以每個元素對于任何特定的事件類型,每次只能注冊一個事件處理程序。
DOM第2級事件模型(也稱為監(jiān)聽器)被設(shè)計來解決這些類型的問題。每個DOM元素都定義名為addEventListener()的方法,用于把事件處理程序(監(jiān)聽器)附加到元素上。這個方法的格式如下所示:
addEventListener(enentType,listener,useCapture)
參數(shù)eventType是一個字符串,用于標(biāo)識將要處理的時間類型。例如:click、mouseover、keydown等。
參數(shù)listener是函數(shù)的引用(或內(nèi)聯(lián)函數(shù)),用于在元素上建立指定類型的處理程序。
參數(shù)useCapture是布爾類型。
利用DOM第2級模型建立事件處理程序
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>DOM Level 2 Events Example</title>
<script type="text/javascript" src="../scripts/jquery-1.2.1.js">
</script>
<script type="text/javascript">
$(function(){
var element = $('#vstar')[0];
element.addEventListener('click',function(event) {
say('Whee once!');
},false);
element.addEventListener('click',function(event) {
say('Whee twice!');
},false);
element.addEventListener('click',function(event) {
say('Whee three times!');
},false);
});
function say(text) {
$('#console').append('<div>'+text+'</div>');
}
</script>
</head>
<body>
<img id="vstar" src="vstar.jpg"/>
<div id="console"></div>
</body>
</html>
以上代碼簡單說明我們能在同一個元素上為同一個事件類型建立多個事件處理程序
在DOM0級事件處理程序是通過把函數(shù)實例的引用指派到DOM元素的屬性而聲明的。
聲明DOM第0級事件處理程序
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>DOM Level 0 Events Example</title>
<script type="text/javascript" src="../scripts/jquery-1.2.1.js">
</script>
<script type="text/javascript">
$(function(){
$('#vstar')[0].onmouseover = function(event) {
say('Whee!');
}
});
function say(text) {
$('#console').append('<div>'+new Date()+' '+text+'</div>');
}
</script>
</head>
<body>
<img id="vstar" src="vstar.jpg" onclick="say('Vroom vroom!')"/>
<div id="console"></div>
</body>
</html>
事件冒泡:在目標(biāo)元素獲得機(jī)會處理事件之后,事件模型檢查目標(biāo)元素的父元素,看是否為同類型事件建立了處理程序。如果是,則也調(diào)用父元素的處理程序。再檢查其父元素,直至檢查到DOM樹的頂部,這個過程稱之為事件冒泡。
事件傳播從起點到DOM樹的頂部
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html id="greatgreatgrandpa">
<head>
<title>DOM Level 0 Bubbling Example</title>
<script type="text/javascript" src="../scripts/jquery-1.2.1.js">
</script>
<script type="text/javascript">
$(function(){
$('*').each(function(){
var current = this;
this.onclick = function(event) {
if (!event) event = window.event;
var target = (event.target) ?
event.target : event.srcElement;
say('For ' + current.tagName + '#'+ current.id +
' target is ' + target.id);
}
});
});
function say(text) {
$('#console').append('<div>'+text+'</div>');
}
</script>
</head>
<body id="greatgrandpa">
<div id="grandpa">
<div id="pops">
<img id="vstar" src="vstar.jpg"/>
</div>
</div>
<div id="console"></div>
</body>
</html>
DOM第2級事件模型
DOM第0級的缺點是,屬性被用于存儲作為事件處理程序的函數(shù)的引用,所以每個元素對于任何特定的事件類型,每次只能注冊一個事件處理程序。
DOM第2級事件模型(也稱為監(jiān)聽器)被設(shè)計來解決這些類型的問題。每個DOM元素都定義名為addEventListener()的方法,用于把事件處理程序(監(jiān)聽器)附加到元素上。這個方法的格式如下所示:
addEventListener(enentType,listener,useCapture)
參數(shù)eventType是一個字符串,用于標(biāo)識將要處理的時間類型。例如:click、mouseover、keydown等。
參數(shù)listener是函數(shù)的引用(或內(nèi)聯(lián)函數(shù)),用于在元素上建立指定類型的處理程序。
參數(shù)useCapture是布爾類型。
利用DOM第2級模型建立事件處理程序
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>DOM Level 2 Events Example</title>
<script type="text/javascript" src="../scripts/jquery-1.2.1.js">
</script>
<script type="text/javascript">
$(function(){
var element = $('#vstar')[0];
element.addEventListener('click',function(event) {
say('Whee once!');
},false);
element.addEventListener('click',function(event) {
say('Whee twice!');
},false);
element.addEventListener('click',function(event) {
say('Whee three times!');
},false);
});
function say(text) {
$('#console').append('<div>'+text+'</div>');
}
</script>
</head>
<body>
<img id="vstar" src="vstar.jpg"/>
<div id="console"></div>
</body>
</html>
以上代碼簡單說明我們能在同一個元素上為同一個事件類型建立多個事件處理程序
相關(guān)文章
jquery實現(xiàn)進(jìn)度條狀態(tài)展示
這篇文章主要為大家詳細(xì)介紹了jquery實現(xiàn)進(jìn)度條狀態(tài)展示,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-03-03jquery創(chuàng)建div 實現(xiàn)代碼
有時候我們需要動態(tài)創(chuàng)建一個div下面是具體的實現(xiàn)代碼,大家只要熟悉了jquery的一些基本用法就能輕松的實現(xiàn)。2009-04-04jQuery中ajax請求后臺返回json數(shù)據(jù)并渲染HTML的方法
今天小編就為大家分享一篇jQuery中ajax請求后臺返回json數(shù)據(jù)并渲染HTML的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08JQuery 兩種方法解決剛創(chuàng)建的元素遍歷不到的問題
本文主要介紹兩種方法,處理JQuery遍歷剛創(chuàng)建的元素問題,簡單易用,希望能幫到大家。2016-04-04