JavaScript(十二)事件
Dom事件
1.DOM0级事件
on事件 只能 监听冒泡阶段 切只能绑定一个事件
dom.onclick = function(){};
2.Dom2级事件
可以绑定多次事件 可以通过设置flag来监听冒泡和捕获阶段 先捕获再冒泡 捕获自上至下 冒泡从下向上
dom.addEventListener('click',function(){},flag) //flag true为捕获 false 为默认冒泡
3.常见的事件
| DOMContentLoaded | DOM加载完成 |
| onblur | 元素失去焦点 |
| onclick | 鼠标点击某个对象 |
| ondbclick | 鼠标双击某个对象 |
| onfocus | 元素得到焦点 |
| onkeydown | 键盘某个按键按下(event.key/event.keycode) |
| onkeypress | 某个按键被按下或按住 |
| onkeyup | 某个按键被松开 |
| onload | 某个页面火元素被加载完成 |
| onmousedown | 当鼠标按键被按下 |
| onmousemove | 当鼠标移动 |
| onmouseout | 当鼠标移出某个元素 |
| onmouseup | 当鼠标按键松开 |
| onmouseover | 当鼠标位于某元素上 |
| onselect | 文本被选定 |
| onresize | 当窗口大被调整 |
| onsubmit | 提交按钮被惦记 |
| onunload | 用户退出页面 |
4.事件的冒泡捕获(低版本的IE没有事件捕获)
<div class="box">
<button>按钮</button>
</div>
<script>
var btn = document.getElementsByTagName('button')[0];
var box = document.getElementsByClassName('box')[0];
box.addEventListener('click',function(){
console.log('box true')
},true)
box.addEventListener('click',function(){
console.log('box false');
},false)
btn.addEventListener('click',function(){
console.log('btn true');
},true);
</script>
结果是 
4.取消事件绑定
取消on事件
btn.onclick=null;
取消二级事件(removeEventListener(type,function-name))
btn.removeEventListener('click',move);//只有有名的函数 事件才能取消
阻止默认事件
event.preventDefault()
或者
return false; //这即停止了 默认事件 也 阻止了冒泡
5.event 对象 ele.onclick = function(event){} (event是一个json 对象 )
currentTarget 目标事件,在冒泡中依然是 触发事件的那个元素
target 时间不妙
bubbles 等属性
offsetX/Y 鼠标距离元素边框的 x/y
screenX/Y 鼠标距离显示器边界的X/Y
clientX/Y 鼠标距离body的X/Y
6.阻止冒泡
cancleBubble 或者 stopPropagation
btn.onclick = function(){
event.cancelBubble=true;
event.stopPropagation();
console.log(event)
}
7.需要的兼容
event = event || window.event;
target = event.target || event.srcElement
8.事件委托
<ul>
<li id="1">1</li>
<li id="2">2</li>
<li id="3">3</li>
<li id="4">4</li>
<li id="5">5</li>
<li id="6">6</li>
<li id="7">7</li>
<li id="8">8</li>
<li id="9">9</li>
<li id="10">10</li>
</ul>
<script>
var oUl = document.getElementsByTagName('ul')[0];
oUl.addEventListener('click',function(event){
var event = event || window.event;
var target = event.target || event.srcEelement; console.log(target.id)
})
</script>
9.获取滚动条距离顶端的距离
document.documentElement.scrollTop;
10.阻止A标签的默认跳转事件
<a href="#"></a>
<a href="" onclick="return false"></a>
<a href="javascript:void(0);"></a>
JavaScript(十二)事件的更多相关文章
- 从头开始学JavaScript (十二)——Array类型
原文:从头开始学JavaScript (十二)--Array类型 一.数组的创建 注:ECMAscript数组的每一项都可以保存任何类型的数据 1.1Array构造函数 var colors = ne ...
- 轻松学习JavaScript十二:JavaScript基于面向对象之创建对象(一)
这一次我们深入的学习一下JavaScript面向对象技术,在学习之前,必要的说明一下一些面向对象的一些术语. 这也是全部面对对象语言所拥有的共同点.有这样几个面向对象术语: 对象 ECMA-262把对 ...
- 轻松学习JavaScript十二:JavaScript基于面向对象之创建对象(二)
四原型方式 我们创建的每一个函数都有一个通过prototype(原型)属性.这个属性是一个对象,它的用途是包括能够由特定类型 的全部实例共享的属性和方法. 逻辑上能够这么理解:prototypt通过条 ...
- JavaScript -- 时光流逝(十二):DOM -- Element 对象
JavaScript -- 知识点回顾篇(十二):DOM -- Element 对象 (1) element.accessKey: 设置或返回accesskey一个元素,使用 Alt + 指定快捷键 ...
- How Javascript works (Javascript工作原理) (十二) 网络层探秘及如何提高其性能和安全性
个人总结:阅读完这篇文章需要20分钟,这篇文章主要讲解了现代浏览器在网络层传输所用到的一些技术, 应当对 window.performance.timing 这个API所有了解. 这是 JavaScr ...
- 了解javascript中的事件(二)
本文目录如下: 零.寒暄 一.事件的分类 二.事件代理 2.1 问题引出 2.2 什么是事件代理 2.3 完整示例 二.事件代理 三.事件代理思想的用处 四.总结 零.寒暄 这篇博客本该出现在两个月以 ...
- webpack4 系列教程(十二):处理第三方JavaScript库
教程所示图片使用的是 github 仓库图片,网速过慢的朋友请移步<webpack4 系列教程(十二):处理第三方 JavaScript 库>原文地址.或者来我的小站看更多内容:godbm ...
- {Python之线程} 一 背景知识 二 线程与进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 七 python与线程 八 Threading模块 九 锁 十 信号量 十一 事件Event 十二 条件Condition(了解) 十三 定时器
Python之线程 线程 本节目录 一 背景知识 二 线程与进程的关系 三 线程的特点 四 线程的实际应用场景 五 内存中的线程 六 用户级线程和内核级线程(了解) 七 python与线程 八 Thr ...
- JavaScript DOM编程艺术-学习笔记(第十二章)
第十二章 1.本章是综合前面章节的所有东西的,一个综合实例 2.流程:①项目简介:a.获取原始资料(包括文本.图片.音视频等) b.站点结构(文件目录结构) c.页面(文件)结构 ②设计(切图) ③c ...
- JavaScript(二):对象、注释、事件!
对象 JavaScript的一个重要功能就是面向对象的功能,通过基于对象的程序设计,可以用更直观.模块化和可重复使用的方式进行程序开发. 一组包含数据的属性和对属性中包含数据进行操作的方法,称为对象. ...
随机推荐
- JDBC操作MySQL出现:This result set must come from a statement that was created with a result set type of ResultSet.CONCUR_UPDATABLE, ...的问题解决
错误如下: This result set must come from a statement that was created with a result set type of ResultSe ...
- MongoDB小结17 - find【查询条件$or】
我们再添加一个游泳的人,并用$in查询游泳的人 db.user.find({"hobby":{"$in":["swimming"]}},{& ...
- 教程 | 使用Sqoop从MySQL导入数据到Hive和HBase
基础环境 sqoop:sqoop-1.4.5+cdh5.3.6+78, hive:hive-0.13.1+cdh5.3.6+397, hbase:hbase-0.98.6+cdh5.3.6+115 S ...
- Androidbuttonshape形状资源码实现
1.项目Src下创建drawable 看文档Develop/API Guides/App Resources/Drawable/Shape Drawable 单词:corners : 角 ; gr ...
- linux网络结构体
一 链路层: (1)局域网(以太网ethernet): *struct eth_header:以太网头部. (ethernet/eth.c) *struct net_device:每一个网络设备都用这 ...
- java 学习第一步---安装JDK以及配置环境变量
1.下载jdk 链接:https://pan.baidu.com/s/1FiTGhxdHK0KTFawdkLT26g 提取码:zcy0 我已经在官网上面下载了1.8的jdk,通过百度云盘分 ...
- YTU 2622: B 虚拟继承(虚基类)-沙发床(改错题)
2622: B 虚拟继承(虚基类)-沙发床(改错题) 时间限制: 1 Sec 内存限制: 128 MB 提交: 487 解决: 393 题目描述 有一种特殊的床,既能当床(Bed)用又能当沙发(S ...
- 别再问什么是Java内存模型了,看这里!
网上有很多关于Java内存模型的文章,在<深入理解Java虚拟机>和<Java并发编程的艺术>等书中也都有关于这个知识点的介绍.但是,很多人读完之后还是搞不清楚,甚至有的人说自 ...
- 洛谷 P1573 栈的操作
题目描述 现在有四个栈,其中前三个为空,第四个栈从栈顶到栈底分别为1,2,3,-,n.每一个栈只支持一种操作:弹出并压入.它指的是把其中一个栈A的栈顶元素x弹出,并马上压入任意一个栈B中.但是这样的操 ...
- 洛谷P2831 愤怒的小鸟——贪心?状压DP
题目:https://www.luogu.org/problemnew/show/P2831 一开始想 n^3 贪心来着: 先按 x 排个序,那么第一个不就一定要打了么? 在枚举后面某一个,和它形成一 ...