js-事件1
本课我将讲述js中的事件及一些浏览器兼容问题
本章主要从以下几个方面讲起:1.事件流 2.事件的浏览器兼容 3.鼠标,键盘事件
1. 事件流
什么叫事件流?
描述的是事件接受的顺序。这句话听起来 还是不怎么容易理解。那么我就 结合两中事件流的方式具体来说一下
事件流有两种方式:冒泡方式, 捕获方式。
对于下面这个页面来说
<!DOCTYPE html>
<html onclick="#">
<head lang="en">
<meta charset="UTF-8">
<title></title>
<link type="text/css" rel="stylesheet" href="index.css"/>
<script type="text/javascript" src="index1.js" charset="gbk"></script>
</head>
<body onclick="#">
<div id="content" onclick="#">
<span id="start" onclick="#">开始</span>
<span id="stop">停止</span>
</div>
</body>
</html>
如果是冒泡方式的话,那么假如你点击的是start这个元素的话,那么会第一响应start这个span的点击事件,但是这个span是在id=content这个div中的,所以你点击这个span其实也就是点击了它的父辈div,以此类推,也就是点击了body,点击了html,所以这几个元素的点击事件都会响应。冒泡方式就是从点击最具体的位置开始响应,然后往父辈元素响应,一层一层的往外冒泡,所以取名叫冒泡方式。
捕获事件就是与冒泡事件恰恰相反,就是它是从最外面的父层开始响应事件,然后慢慢往子元素递进。
一般IE浏览器采取的方式都是冒泡方式的
2.事件兼容问题
其次,就事件的方式来说,有三种事件方式:HTML事件,DOM0,DOM2.三种事件方式。
首先来说一下什么事html事件方式
我们通常给一个按钮附加点击事件,如下所示:
<input type="button" id="input" onclick="function(){.....}"/>
或者
<input type="button" id="input" onclick="play()"/>
<script type="text/javascript" >
function play(){
.....
}
</script>
DOM0级事件处理方式:
<script type="text/javascript">
Object.onclick=function(){
....
}
如果想取消这个点击事件,只需要下面操作
Object.onclick=null;
</script>
DOM2级事件处理方式
<script type="text/javascript">
Object.addEventListener("EventType",function,value);//这种方式给某个元素绑定某个事件,其中EventType是事件类型,比如click,mouseout等,function指的是要调用的事件名,value表是的是布尔值,flase表示的冒泡方式,true表示的是事件捕获方式。
Object.removeEventListener("EventType",function,value);
在IE中DOM2的方式有点不一样
Object.attachEvent("EventType",function),只有两个参数,跟上面一样,没有value这个参数,因为IE中默认的是冒泡形式。
Object.detachEvent("Event TYpe",function)一样的用来解除这个事件。
</script>
其中千万要注意一点。就是不管DOM0级还有DOM2级中的IE中的方式,事件前面都有on例如onclick,onmouseover,等但是在DOM2级中的addEventListener方式中事件前面不要加on,例如click.
js-事件1的更多相关文章
- dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来
dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...
- 什么是JS事件冒泡?
什么是JS事件冒泡?: 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理 程序或者事件返回true,那么 ...
- js事件技巧方法整合
window.resizeTo(800,600); //js设置浏览器窗口尺寸 window.open (function(){ resizeTo(640,480);//设置浏览器窗口尺寸 moveT ...
- js事件浅析
js中关于DOM的操作很多,因此js事件机制也就尤为重要. 事件绑定形式: 一. 内联形式 耦合度高,不利于维护 <button onclick="alert('你点击了这个按钮'); ...
- js 事件大全
Js事件大全一般事件 事件 浏览器支持 描述onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击onDblClick IE4|N4|O 鼠标双击事件onMouseDo ...
- 原生JS事件绑定方法以及jQuery绑定事件方法bind、live、on、delegate的区别
一.原生JS事件绑定方法: 1.通过HTML属性进行事件处理函数的绑定如: <a href="#" onclick="f()"> 2.通过JavaS ...
- JS事件
JS事件: 声明:为了事件对象event跨浏览器兼容: var oEvent==ev||event; 所以在下面用到 event 的地方都用 oEvent 代替 1)doucument的 ...
- 原生js事件和jquery事件的执行顺序问题
场景:近日,写前端页面时候,在针对输入框input操作时,用到了jquery的插件,插件中使用了jquery的focus()和blur()方法.但是同时,又需要在插件之外再针对输入框的获取焦点和失去焦 ...
- 特殊js事件
1:点击enter事件 $(document).keypress(function(e) { // 回车键事件 if(e.which == 13) { submitForm(); } }); 2:JQ ...
- js 事件
事件:一般用于浏览器与用户操作进行交互 js事件的三种模型:内联模型.脚本模型.DOM2模型 内联模型:事件处理函数是HTML标签的属性 <input type="button&quo ...
随机推荐
- Solr7.x学习(2)-设置开机启动
1.创建solr用户 useradd solr 2.设置solr-7.7.2目录拥有者 cd /usr/local/ chown -R solr:solr solr-7.7.2 3.在/etc/ini ...
- 【转】调用百度API,HTML在线文字转语音播报
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Prometheus安装部署说明
本文主要介绍了如何二进制安装Prometheus.使用 Node Exporter 采集主机信息并使用Grafana来进行图形化的展示. 1. 安装Prometheus Server Promethe ...
- Chartjs 简单使用 ------ 制作sin cos 折线图
Chart.js 一款简单干净的图表工具,基于html5 的Javascript. 可以用来制做条形,扇形,折线,混合等等的强大工具 图表要放在html 的 cancas 标签中 <canv ...
- js2048小游戏
js2048小游戏,方格是怎么合并和移动的 index.html <html> <head> <meta charset="utf-8"> &l ...
- spring Valid @Pattern 常见的验证表达式
1 匹配首尾空格的正则表达式:(^\s*)|(\s*$) 2 整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2}$ 3 只能输入数字:"^[0-9]*$". 4 只 ...
- 分享一个Linux C++消息通信框架TCPSHM
由于本人从事行业关系,Linux环境下的低延迟通信是我关注的技术之一.要达到极端的低延迟,当然同机器内IPC比网络通信快,而Linux IPC方式中无疑是共享内存延迟最低.不过相对于TCP这种通用的通 ...
- FusionInsight大数据开发---sorl应用开发
sorl应用开发 要求: 了解Solr应用开发适用场景 熟悉Solr应用开发流程 熟悉并使用Solr常用API 理解Collection设计基本原则 应用开发实践 Solr简介 Solr是一个高性能, ...
- CRLF will be replaced by LF in XXX when git commit
转载自Git-warning: CRLF will be replaced by LF in XXX 今天,普通平凡的一天,平凡的使用 git add .,然后又出现一个之前没遇到的错误提示 . 真开 ...
- Linux(二)各种实用命令
继续Linux命令学习,没有什么捷径,每个命令都去敲几遍就熟悉了,第二篇学习的是一些比较实用类的命令,主要是从开发的角度进行学习,并不深入,话不多说,开始! 一.系统管理类 1.1 stat --st ...