JS事件

事件流


事件

事件就是在变成时系统内发生的动作或者发生的事情

  • 单击
  • 双击
  • 鼠标放置
  • 表单内容发生变化
  • 拖拽
  • 页面滚动
  • 触发/失去焦点
  • 键盘按下
  • 提交表单
  • ......

JS 中事件就是一个对象

DOM事件流

  • 三个阶段
    • 事件捕获阶段,处于目标阶段,事件冒泡阶段
    • image.png
    • 在捕获阶段和冒泡阶段分别可以对事件进行监听

事件监听函数

  • 当事件发生时执行的函数
  • 三种绑定方法
    1. 在 html 中绑定,尽量不用
      • <div onclick="sayHello">点我</div>
    2. 给 dom 元素的 onclick 赋值
      • $btn.onclick = function(e){console.log('点我')}
      • 这个写法只能点击一次触发一次,相当于更改属性绑定的函数,那么每次点击的时候,只能触发一次属性
    3. 调用 dom 的 addEventListener 函数
      • $btn.addEventListener('click', function(e){console.log('点我')}, true)
      • 使用这个函数的一个好处就是,可以给一个元素绑定多个事件监听,即便是这个事件是相同事件,也可以点击一次多次触发,因为它写的方式就是调用函数,函数是可以多次调用的

addEventListener

  • target.addEventListener(type, listener, options)
    • type:事件类型
    • listener:事件处理方法
    • options:可选,默认全是 false。{capture:是否捕获阶段监听,once:是否只监听一次,passive:是否忽略 preventDefault}
  • target.addEventListener(type, listener, useCapture)
    • useCapture:可选,true表示在捕获阶段调用 listener,false表示在冒泡阶段处理
  • target.removeEventListener
    • target.removeEventListener('click', handler)
    • target.removeEventListener('click', handler, true)

阻止事件传播


  • e.stopPropagation()
  • 我们知道事件触发分为捕获阶段和冒泡阶段,并且会着一执行对应的事件,当我们在其中一个事件监听的时候,使用阻止事件传播,那么后续的事件就不会进行下去。
$('.child').addEventListener('click', function(e){
    console.log('事件开始处理')
    e.stopPropagation()
}, true)

阻止默认事件

  • e.preventDefault()
    • 链接不自动跳转
    • 表单不自动提交
  • 与passive选项的关系
    • 移动端滚动性能优化

事件代理


什么是事件代理

  • 事件绑定代理给父元素,由父元素根据事件来源统一处理
  • 适用于可能会新增子元素场景
  • 事件代理实际上是事件冒泡的应用

为什么用事件代理


  • 我们又一系列的子元素,这些子元素都有相类似的事件,我们在刚开始就给这些元素添加这些事件
  • 但是后面通过其他方式创建的新元素没有这些事件,只能在创建之后还给这个元素新添事件
  • 换一个思路:我们部不对单个元素添加绑定,而是注意到父元素上,使用冒泡原理,将事件绑定在父元素上面
  • 事件具有一个path属性,通过这个path属性,可以拿到对应的对象
  • image.png

常见事件


  • click:点击
  • dblclick:双击左键
  • mouseover:鼠标悬停,如果悬停在孩子身上就不执行
  • mouseout:鼠标离开,离开到孩子身上,会执行
  • mouseenter:只执行一次,如果里面是孩子,也只执行一次,更符合我们的预期
  • mouseleave:只执行一次,如果里面是孩子,也只执行一次,更符合我们的预期
  • hover:鼠标悬停事件
  • focus:一般是表单拿到焦点
  • blur:一般是表单失去焦点
  • keyup:按键松开,使用起来并不方便
  • keydown:按键按下,使用起来并不方便
  • change:使用起来比较方便,内容变化就触发
  • submit:form表单的提交事件
  • scroll:滚动页面窗口的时候
  • resize:调整页面大小的时候
  • window.onload:资源全部加载完毕的时候
  • DOMContentLoaded:页面的DOM全部加载完毕之后
  • $('img').onload:图片加载完毕事件
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354

推荐阅读更多精彩内容

  • Dom事件 事件是一种异步编程的实现方式,本质上是程序各个组成部分之间的通信。DOM支持大量的事件 (一) Eve...
    woow_wu7阅读 1,773评论 0 1
  • 事件流分为两种,捕获事件流和冒泡时间流 捕获事件流:从根节点出发开始执行,一直往子节点查找执行,直到查到到根节点。...
    路上灵魂的自由者阅读 393评论 0 0
  • js事件是为了实现用户交互,比如当用户鼠标点击或者键盘输入时,浏览器会监听截获并且通知js做出反馈执行相应的函数,...
    深度剖析JavaScript阅读 754评论 0 7
  • 事件流 Click Me 冒泡型事件:事件按照从最特定的事件目标到最不特定的事件目标的顺序触发。触发的顺序是:di...
    醋留香阅读 798评论 0 1
  • 什么是事件?事件是一种通知机制,按照事件类型进行匹配 事件侦听对象div.addEventListener("cl...
    learninginto阅读 384评论 0 8