jQuery学习4 浏览器的事件模型

2016-02-19 14:12 1 1 收藏

下面是个超简单的jQuery学习4 浏览器的事件模型教程,图老师小编精心挑选推荐,大家行行好,多给几个赞吧,小编吐血跪求~

【 tulaoshi.com - Web开发 】

首先要知道DOM的两级模式:DOM0级和DOM2级

在DOM0级事件处理程序是通过把函数实例的引用指派到DOM元素的属性而声明的。

声明DOM第0级事件处理程序
代码如下:
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"
html
head
titleDOM 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

事件冒泡:在目标元素获得机会处理事件之后,事件模型检查目标元素的父元素,看是否为同类型事件建立了处理程序。如果是,则也调用父元素的处理程序。再检查其父元素,直至检查到DOM树的顶部,这个过程称之为事件冒泡。

事件传播从起点到DOM树的顶部
代码如下:
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"
html id="greatgreatgrandpa"
head
titleDOM 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级的缺点是,属性被用于存储作为事件处理程序的函数的引用,所以每个元素对于任何特定的事件类型,每次只能注册一个事件处理程序。

DOM第2级事件模型(也称为监听器)被设计来解决这些类型的问题。每个DOM元素都定义名为addEventListener()的方法,用于把事件处理程序(监听器)附加到元素上。这个方法的格式如下所示:

addEventListener(enentType,listener,useCapture)

参数eventType是一个字符串,用于标识将要处理的时间类型。例如:click、mouseover、keydown等。

参数listener是函数的引用(或内联函数),用于在元素上建立指定类型的处理程序。

参数useCapture是布尔类型。

利用DOM第2级模型建立事件处理程序
代码如下:
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"
html
head
titleDOM 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

以上代码简单说明我们能在同一个元素上为同一个事件类型建立多个事件处理程序

来源:https://www.tulaoshi.com/n/20160219/1606428.html

延伸阅读
百度浏览器设置为默认浏览器方法来啦~百度浏览器是大家经常使用的一款浏览器,那么怎么将百度浏览器设置成默认浏览器呢?下文小编就为大家带来百度浏览器设置为默认浏览器的方法,一起去看下吧。 百度浏览器下载地址: 百度浏览器2015官方下载电脑版 百度浏览器设置为默认浏览器方法: 1、打开...
标签: Web开发
chrome 是免费的开源 web 浏览器,它由 Google 开发。 Chrome 是什么? 当 Google 决定开发一款浏览器时,他们需要彻底地重新谋划这款浏览器,这是因为如今的浏览器与仅需要浏览简单的文本页面时有很大的不同,现在,我们在浏览器上发邮件、购物、付账单,以及运行其他的大型应用程序。 下载 Google Chrome 新特性 在经过 15 个 Beta 测...
标签: Web开发
AJAX - 浏览器支持 AJAX 的要点是 XMLHttpRequest 对象。 不同的浏览器创建 XMLHttpRequest 对象的方法是有差异的。 IE 浏览器使用 ActiveXObject ,而其他的浏览器使用名为 XMLHttpRequest 的 JavaScript 内建对象。 如需针对不同的浏览器来创建此对象,我们要使用一条 "try and catch" 语句。您可以在我们的 JavaScript 教...
标签: 浏览器
YY浏览器如何清理浏览器缓存?   YY浏览器是上网时,会经常使用到的一款网页浏览器,在用户使用浏览器的过程中,都避免不了浏览器在系统中生成相应的缓存文件,再或者用户浏览了一些隐私网址,想要清理这些数据我们就需要通过浏览器自带功能来清理,那么在YY浏览器下如何清理浏览器缓存文件呢?下面看小编为大家带来的清理方法,需要的...
标签: 浏览器
360极速浏览器浏览器头像的功能 1.登录网络帐户 点击浏览器头像可登录360帐户。登录360帐户的状态下,您的收藏夹、浏览器配置的修改都将自动备份到360帐户中。之后随 时登录360帐户即可自动上述内容同步到浏览器中。 2.更换头像 您可以在头像菜单里选择您喜欢的头像,用于装饰浏览器。陆续将提供更多精美的头像供您选用。 ...

经验教程

907

收藏

62
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部