事件

不同的事件类型

UI事件

load

Web页面加载完成

unload

Web页面正在卸载(通常是因为请求了一个新页面)

error

浏览器遇到JavaScript错误或有不存在的资源

resize

浏览器窗口的大小发生了变化

scroll

用户使用滚动条移动了页面

键盘事件

keydown

用户第一次按下一个键

keyup

用户松开了一个键

keypress

键入了一个字符(按住这个键时会反复触发)

鼠标事件

click

用户在同一个元素上按下并松开一个按键

dbclick

连续两次按下并松开一个按键

mousedown

在一个元素上按下鼠标按键

mouseup

在一个元素上松开鼠标按键

mousemove

移动鼠标(不会发生在触摸屏上)

mouseover

将鼠标移到一个元素上(同上)

mouseout

将鼠标从一个元素上移开(同上)

焦点事件

focus/focusin

元素得到焦点

blur/focusout

元素失去焦点

表单事件

input

<input>/<textarea>元素中的值发生了变化或拥有contenteditable属性的元素中的值发生了变化

change

复选框、单选框或单选按钮的值发生了变化

submit

用户提交表单

reset

用户单击了表单上的重置按钮

cut

从一个表单域中剪切了内容

copy

从一个表单域中复制了内容

paste

向一个表单域粘贴了内容

select

在一个表单域中选中了一些文本

变动事件

DOMSubtreeModified

文档发生了变化

DOMNodeInserted

一个节点被插入为另一个节点的直接子节点

DOMNodeRemoved

一个节点被从另一个节点中移除

DOMNodeInsertedIntoDocument

一个节点被插入为另一个节点的后代

DOMNodeRemoveFromDoucument

一个节点被从其祖先节点上移除

事件如何触发JavaScript代码

1.选中需要使用脚本进行事件响应的元素节点
2.声明需要在选中节点上响应触发的事件
3.指定当事件发生时需要运行的代码

将事件绑定到元素的三种方法

1.HTML事件处理程序(不要使用)
一个元素绑定多个事件的时候可能会出错
2.传统的DOM事件处理程序
每个事件处理程序只能附加一个函数
语法:element.onevent = functionName;
3.第2级DOM监听器
它可以同时触发多个函数,但是在旧的浏览器中不被支持。
语法:element.addEventListener(‘event’,functionName[,Boolean]);如果需要传参数,要用一个匿名函数将语句封装起来,如果旧版本浏览器不支持的话,就使用if语句分情况使用(addEventListener可以替换为attachEvent)

事件流

HTML元素都位于另一些元素中。如果移动鼠标到一个链接上,同样会把鼠标移到它的父元素上,或者点击它的父元素



就是一个元素和其祖先元素或后代元素上都有事件处理程序时,它们的执行顺序问题。addEventListener里面第三个参数如果是true表示捕获方式,false表示冒泡方式。

事件对象

属性:

target:事件的目标(与用户进行交互的最具体的元素),在IE5--IE8中等同于srcElement
type:发生的事件的类型,等同于type
cancelable:是否可以撤销事件在这个元素上的默认行为,IE5--IE8中不支持

方法:

preventDefault():撤销这个事件的默认行为(如果可以撤销的话),等同于returnValue
stopPropagation():停止事件继续冒泡或向下捕获的过程,等同于cancelBubble



事件委托

为大量的元素创建事件监听器会造成页面速度下降,事件流允许你在父元素上监听事件
额外优势:
适用于新的元素:如果向DOM树中添加了新的元素,那么不需要再向这个新元素上添加事件处理程序。
解决this关键字的限制
简化代码:易于维护

改变默认行为

事件对象有一些方法可以改变一个元素的默认行为,以及它的祖先元素如何对这个事件做出响应。
preventDefault()有一些事件,比如点击链接或提交表单,会把用户导向另一个页面。为了阻止这种行为可以使用此方法。
stopPropagation()处理完某个元素上的事件之后,可能需要阻止这个事件向其祖先元素继续冒泡传播。

使用事件委托 例子流程图

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容

  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,464评论 1 11
  • 本节介绍各种常见的浏览器事件。 鼠标事件 鼠标事件指与鼠标相关的事件,主要有以下一些。 click 事件,dblc...
    许先生__阅读 2,393评论 0 4
  • 总结: 鼠标事件 1.click与dbclick事件$ele.click()$ele.click(handler(...
    阿r阿r阅读 1,591评论 2 10
  • 13.1 事件流 “DOM2级事件”规定事件流包括3个阶段:事件捕获阶段,处于目标阶段,事件冒泡阶段。事件捕获表示...
    Elevens_regret阅读 396评论 0 0
  • JavaScript 与 HTML 之间的交互是通过事件实现的。事件,就是文档或浏览器窗口中发生的一些特定的交互瞬...
    LemonnYan阅读 669评论 0 4