JavaScript常用的事件模型
一、事件绑定模型
DOM0事件模型
1.内联模型(行内绑定):将函数名直接作为HTML标签中事件属性的属性值
<button id="btn" onclick="func()">内联模型绑定</button>
缺点:不符合W3C中关于内容与行为分离的基本规范
2.脚本模型(动态绑定):通过在JS中选中某个节点,然后给节点添加onclick属性。
<button id="btn1">脚本模型绑定</button>
<script>
document.getElementById("btn1").onclick = function () {
alert("");
};
</script>
优点:符合W3C中关于内容与行为分离的基本规范,实现HTML与JS的分离。
3.DOM0共有缺点:
a.同一个节点只能添加一次同一事件,如果添加多次最后一个生效
b.通过DOM0绑定的事件,一旦绑定将无法取消(虽然行内绑定可以removeAttribute但不算)
DOM2事件模型
1.添加DOM2事件绑定:
①IE8之前,使用.attachEvent("onclick",func3);谷歌不支持这种写法
②IE8之后,使用.addEventListener("click",func3,true/false);
参数三:false(默认)表示事件冒泡;传入true 表示事件捕获;
③兼容所有浏览器的处理方式:
<button id="btn2">DOM2模型绑定</button>
<script>
var btn2 = document.getElementById("btn2");
if(btn2.attachEvent){
btn2.attachEvent("onclick",func3);
}else{
btn2.addEventListener("click",func3);
}
function func3(){
alert("");
}
</script>
2.DOM2绑定的优点
①同一个节点可以绑定多个同类事件
<script>
btn2.addEventListener("click",function(){
alert("第二次绑定click事件");
});
</script>
②使用DOM2绑定的事件可以有专门的函数进行事件取消
3.DOM2取消事件绑定:
①使用.attachEvent("onclick",func3);绑定,要用.detachEvent("onclick",func3);取消
②使用.addEventListener("click",func3);绑定,要用.removeEventListener("click",func3);取消
③兼容所欲浏览器的处理方式:
注意:如果DOM2绑定的事件,需要取消,则绑定事件时,回调函数必须是函数名,而不能是匿名函数。
因为取消事件时需要传入函数名进行取消
<button id="btn3">取消DOM2模型绑定</button>
<script>
var btn3 = document.getElementById("btn3");
btn3.onclick = function () {
if(btn2.detachEvent){
btn2.detachEvent("onclick",func3);
}else {
btn2.removeEventListener("click",func3);
}
alert("事件已取消!");
};
</script>
二、事件流模型
1.事件冒泡(false或默认):当触发一个节点的事件时,会从当前节点开始,依次触发其祖先节点的同类型事件,直到DOM根节点
2.事件捕获(true):当触发一个节点的事件时,会从DOM根节点开始,依次触发其祖先节点的同类型事件,直到当前节点自身。
↓ DOM根节点 ↑ 捕 冒 ↓ 祖先节点 ↑ 获 泡 ↓ 当前节点 ↑
3.什么时候事件冒泡,什么时候事件捕获?
①当使用addEventListener绑定事件,第三个参数传入true时表示事件捕获;
②除此之外全都是事件冒泡
<body>
<div id="div1">1
<div id="div2">2
<div id="div3">3</div>
</div>
</div>
</body>
<script>
var div1 = document.getElementById("div1");
var div2 = document.getElementById("div2");
var div3 = document.getElementById("div3");
//事件冒泡
div1.addEventListener("click",function () {
console.log("div1 click 1");
});
div2.addEventListener("click",function () {
//myParagraphEventHandler();
console.log("div2 click 2")
});
div3.addEventListener("click",function () {
console.log("div3 click 3");
}); //事件捕获
div1.addEventListener("click",function () {
console.log("div1 click 1");
},true);
div2.addEventListener("click",function () {
//myParagraphEventHandler();
console.log("div2 click 2")
},true);
div3.addEventListener("click",function () {
console.log("div3 click 3");
},true);
</script>
4.阻止事件冒泡:
①IE10之前(包含10),使用:e.cancelBubble = true;
②IE10之后,使用:event.stopPropagation();
function myParagraphEventHandler(e) {
e = e || window.event;
if (e.stopPropagation) {
e.stopPropagation(); //IE10以后和其他浏览器
} else {
e.cancelBubble = true; //IE10以前(包含10)
}
}
5.阻止默认事件:
①IE10之前(包含10),使用:e.returnValue = false;
②IE10之后,使用:e.preventDefault();
<a href="01-事件笔记.html" onclick="func()">超链接</a>
<script>
function func(e) {
e = e || window.event;
eventHandler(e);
alert("您点击了超链接但是您走不了哈哈哈哈哈!!!");
}
//阻止默认事件的函数
function eventHandler(e) {
e = e || window.event;
// 防止默认行为
if (e.preventDefault) {
e.preventDefault(); //IE10以后和其他浏览器
} else {
e.returnValue = false; //IE10以前(包含10)
}
}
</script>
JavaScript常用的事件模型的更多相关文章
- 说说JavaScript中的事件模型
1.javascript中为元素添加事件处理程序的方法有以下几种方式,可以为javascript元素添加事件处理程序 (1) 直接将事件处理代码写在html中(2) 定义一个函数,赋值给html元素的 ...
- 理解javascript中的事件模型
javascript中有两种事件模型:DOM0,DOM2.而对于这两种的时间模型,我一直不是非常的清楚,现在通过网上查阅资料终于明白了一些. 一. DOM0级事件模型 DOM0级事件模型是早期的事件 ...
- JavaScript中的事件模型
JS中的事件 1.鼠标事件 onclick ondbclick onmouseover onmouseout 2.HTML事件 onload onunload onsubmit ...
- Javascript事件模型系列(一)事件及事件的三种模型
一.开篇 在学习javascript之初,就在网上看过不少介绍javascript事件的文章,毕竟是js基础中的基础,文章零零散散有不少,但遗憾的是没有看到比较全面的系列文章.犹记得去年这个时候,参加 ...
- JavaScript DOM事件模型
早期由于浏览器厂商对于浏览器市场的争夺,各家浏览器厂商对同一功能的JavaScript的实现都不进相同,本节内容介绍JavaScript的DOM事件模型及事件处理程序的分类. 1.DOM事件模型.DO ...
- javascript之BOM事件注册和案例
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- java基础66 JavaScript中的事件、localtion对象、screen对象(网页知识)
1.JavaScript中的事件注册 1.1.事件的注册方式 方式1:直接在html元素上注册 <body onLoad="ready()"></body > ...
- javascript中0级DOM和2级DOM事件模型浅析
Javascript程序使用的是事件驱动的设计模式,为一个元素添加事件监听函数,当这个元素的相应事件被触发那么其添加的事件监听函数就被调用: <input type="button&q ...
- JavaScript事件模型及事件代理
事件模型 JavaScript事件使得网页具备互动和交互性,我们应该对其深入了解以便开发工作,在各式各样的浏览器中,JavaScript事件模型主要分为3种:原始事件模型.DOM2事件模型.IE事件模 ...
随机推荐
- Linux0.11 中对地址的管理
个字节,段信息无法直接存放在段寄存器中(段寄存器只有2字节).Intel的设计是段描述符集中存放在GDT或LDT中,而段寄存器存放的是段描述符在GDT或LDT内的索引值(index). Linux中逻 ...
- 【Qt编程】基于Qt的词典开发系列<二>--本地词典的设计
我设计的词典不仅可以实现在线查单词,而且一个重大特色就是具有丰富的本地词典库:我默认加入了八个类型的词典,如下所示: 由于是本人是通信专业,因此加入了华为通信词典.电子工程词典,又由于我喜爱编程,也加 ...
- SVM实验
说明: 1)α2=0表示第二个样例不在分类面上,在分类面上的点αi均不为零. 2)二次项矩阵,可以通过矩阵相乘相加方法得到,如上例 3)目标函数变为负值,是为了照顾matlab的标准型. 假定应用多项 ...
- LeetCode之“散列表”:Single Number
题目链接 题目要求: Given an array of integers, every element appears twice except for one. Find that single ...
- Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路
Android ROM开发(三)--精简官方ROM并且内置ROOT权限,开启Romer之路 相信ROM的相关信息大家通过前几篇的学习都是有所了解了,这里就不在一一提示了,这里我们下载一个官方包,我们还 ...
- 在 Linux 下用 mkdir 命令来创建目录和子目录
mkdir 是什么呢 Mkdir 是一个用来在 Linux 系统下创建目录的命令.此命令属于内建命令. 运行 mkdir 命令 你可以在你的控制台直接键入 mkdir 来使用它. $ mkdir 默认 ...
- 【编程练习】快速select算法的实现
代码来自: http://blog.csdn.net/v_JULY_v 算法思想: // Quick_select.cpp : 定义控制台应用程序的入口点. // #include "std ...
- ZooKeeper 权限管理
这其中一个显而易见的问题就是权限:如果我的数据被别人动了怎么办? 方案一:采用ZooKeeper支持的ACL digest方式,用户自己定义节点的权限 这种方案将zookeeper的acl和diges ...
- 和菜鸟一起学linux之DBUS基础学习记录
D-Bus三层架构 D-Bus是一个为应用程序间通信的消息总线系统, 用于进程之间的通信.它是个3层架构的IPC 系统,包括: 1.函数库libdbus ,用于两个应用程序互相联系和交互消息. 2.一 ...
- javascript内置对象速查(一)
字符串对象 var str = new String("Hello World"); 可以调用其中的一些方法: str.length str.big 日期对象 var dt = n ...