JavaScript基础知识点--DOM事件

什么是事件

事件就是文档或浏览器窗口中发生的一些特定的交互瞬间

HTML 事件

直接在 HTML 元素标签内添加事件,执行脚本

语法

<tag 事件="执行脚本"></tag>

功能

在 HTML 元素上绑定事件

不建议使用 HTML 事件

  1. 多元素绑定相同事件时,效率低

  2. 不建议在 HTML 元素中写 JavaScript 代码

说明

执行脚本可以是一个函数的调用

DOM 0级事件

  1. 通过 DOM 获取 HTML 元素

  2. (获取 HTML 元素).事件 = 执行脚本

语法

ele.事件 = 执行脚本

功能

在 DOM 对象上绑定事件

说明:

执行脚本可以是一个匿名函数,也可以是一个函数的调用

除非调用匿名函数,否则调用普通函数不能加括号

鼠标事件

事件名称 作用
onload 页面加载时触发
onclick 鼠标点击时触发
onmouseover 鼠标滑过时触发
onmouseout 鼠标离开时触发
onfocus 获得焦点时触发
onblur 失去焦点时触发
onchange 域的内容改变时发生
onsubmit 表单中的确认按钮被点击时发生,这个事件不是加在按钮上,而是表单上
onmousedown 鼠标按钮在元素上按下时触发
onmousemove 在鼠标指针移动是发生
onmouseup 在元素上松开鼠标按钮时触发
onresize 当调整浏览器窗口的大小时触发
onscroll 拖动滚动条滚动时触发
ondblclick 双击元素触发

onfocus 事件用于 input 标签 type 为 text、password 和 textarea 标签

键盘事件与 keyCode 属性

事件名称 作用
onkeydown 在用户按下一个键盘按键时发生
onkeypress 在按下键盘按键时发生(只会响应字母与数字符号)
onkeyup 在键盘按键被松开时发生
keyCode 返回 onkeypress、onkeydown 或 onkeyup 事件触发的键的值的字符代码,或键的代码
charCode 返回键的ASCll码
textInput 只有在可编辑区域,按下能够输入实际字符的键时才会触发此事件

textInput 详解

第一种情况

输入框中按下enter键,触发的只有keypress事件

第二种情况

按下a键,触发keypress和textinput事件

键盘事件触发顺序

  1. onkeydown

  2. onkeypress

  3. onkeyup

event

event 代表事件的状态,如触发 event 对象的元素、鼠标的位置及状态等

获取按键的字符代码

document.onkeypress = function(event){
    console.log(event.keyCode);
}

charCode与keyCode的区别

charCode 返回onkeypress事件触发键值的字母代码。

keyCode 返回 onkeydown 或 onkeyup 事件的键的代码。

其他事件

事件名称 触发条件
DOMNodeRemoved Document 中任意元素被删除就会触发
DOMSubtreeModified DOM结构中发生任何变化都会触发
DOMNodeRemoveFromDocument 从文档中移除之前会触发
DOMNodeInserted Document 中任意元素被添加就会触发
DOMNodeInsertedIntoDocument 从文档中添加之前被触发

HTML5新增的事件

事件名称 触发条件
DOMContentLoaded 在DOM树之后就会触发,不理会图像、JavaScript文件、CSS文件或其他资源是否已经下载。速度一定快于load事件
readystatechange 请参照下面的描述
hashchange 对象一定是window。#号后面的值变化时触发

readystatechange 事件详解

提供文档或者元素加载过程,但很难预料与load事件一起使用时候

返回值

  1. uninitialized:尚未初始化

  2. loading:对象正在加载数据

  3. interactive:可以操作对象,但还没有完全加载

  4. 对象已经加载完毕

但其他资料并不是这样写的

请参照菜鸟教程--readystatechange 事件

移动端常用的事件类型

事件类型名称 触发
touchstart 手指触摸屏幕
touchmove 手指在屏幕上滑动
touchend 手指从屏幕上移开

关于 this 指向

在事件触发的函数中,this 是对该 DOM 对象的引用

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

推荐阅读更多精彩内容

  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,491评论 1 11
  • 一、JavaScript鼠标事件 通常,事件处理器的命名原则是,在事件名称前加上前缀on。例如,对于click事件...
    挥剑斩浮云阅读 544评论 0 1
  • 基本概念 事件是一些特定动作发生时所发出的信号,JavaScript中的事件是可以被 JavaScript 侦测到...
    Zd_silent阅读 461评论 0 1
  • 一般我们可以通过Javascript,在HTML文档元素中注册不同事件处理程序。 事件通常与函数结合使用,函数不会...
    深度剖析JavaScript阅读 490评论 0 6
  • JavaScript--DOM事件 事件就是文档或浏览器窗口中发生的一些特定的交互瞬间。 一、HTML事件 语法:...
    我可能是个假开发阅读 419评论 1 5