JavaScript—事件

声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。

JavaScript—事件

事件机制:

在用户使用键盘、鼠标等设备进行操作时,实际上每一次的操作都是在发起一个事件。

当我们的鼠标点击到窗口上的按钮时,并不是鼠标的箭头真正点击到这个按钮了,而是鼠标发出了一个动作事件,然后这个事件先被传送到了操作系统的命令处理带,然后再传送到负责显示图形的图像数据层,事件到这里后图像数据层会先看哪个程序的窗口在最上面(因为不是在最上面就没必要看了),再根据鼠标提供的X Y坐标确认点击的是哪个窗口上的按钮,接着再确认这个窗口是哪个程序。

确认完毕后,图像数据层就会将这个动作事件提交给相对应的执行程序,执行程序里的代码先寻找是哪个位置的数据哪个对象提供的,进行一系列的搜索,找到后这个对象就会执行相对应的代码,然后再将执行后的显示传送到图像数据中心进行显示。我们就会看到鼠标点击到了这个按钮。

之所以平时使用的时候没感觉出来,是因为这一系列的复杂的机制都是在瞬间完成的,只有在电脑卡顿的情况下才能感觉到点击后要等一段时间才会做出相应的响应。

示意图:

事件委托:

这其中有一个事件委托的概念,我们需要在代码中把事件委托也可以说是注册到按钮上,这时会有一个监听器监听着这个按钮,当用户点击按钮时就会去调用委托事件中的代码,这些代码都写在函数中。

所以简单来说,就是把一个写好的函数通过事件委托到按钮上,当用户点击按钮后,就会调用那个函数,函数里的代码就会执行。

例如:我把一段打印Hello World的函数,通过事件委托到按钮上,当我点击这个按钮的时候就会调用这个函数,函数执行完之后就会打印Hello World。

以上提到的事件只是众多事件类型中的一种点击事件,事件是有很多种类型的,例如:鼠标的单击、双击、滚轴,键盘的按键弹起、按下、长按等等,反正很多就是了,还有一些是某些元素特有的事件。

在介绍如何委托事件前,先介绍一下如何控制元素对象(标签对象),因为有些委托事件的方式需要去获得元素对象来进行事件的委托:

第一种获得方式是通过id去获得,这种方式需要用document对象去调用getElementById函数并传递元素的id值,就可以获得该id值的元素对象。

代码示例:

运行结果:

从审查元素中可以看到id值为test_sbutton的元素中的value值,为我js代码里设置的值。

错误示例:

因为代码是是从上至下解析的,如果你要获得body里面的元素对象,却把script写在了body前面,所以当执行js里面获得元素对象的代码时就会报错:

代码示例:

运行结果:

第二种方式是直接使用id值,可以直接拿id值去定义该元素对象里面的属性值:

代码示例:

运行结果:

以上只是介绍比较常见的两种获得元素对象的方式,除此之外还有很多种获得方式,可以参考以下文章:

http://www.jb51.net/article/64874.htm

注意:id值不要设置重复的最好保持唯一性,如果设置重复的话,js就不能直接获得元素对象,而是会获得一个对象数组,如果遇到id值重复的情况下,就得遍历数组去获得对象:

代码示例:

运行结果:

思维导图:

接下来开始介绍JavaScript中给元素委托事件的三种常用的方式:

第一种方式,写好函数代码后,通过元素中的事件属性进行委托,下面用鼠标事件中的mouseout和mouseover事件进行演示,mousseout事件在鼠标移动出该元素时会触发,mouseover事件在鼠标移动进该元素时会触发,属于焦点类的事件:

代码示例:

运行结果:

当鼠标的光标移动进按钮时会触发mouseover事件,移动出按钮时会触发mousseout事件,然后就会调用委托到事件中的函数代码,函数被调用执行就会在控制台中输出这些信息。

所谓焦点就是鼠标的光标的位置,例如当你在文本框输入文字时需要点击一下文本框才能输入,这就是要让文本框获得鼠标焦点。

第二种方式,通过id获取元素对象,然后通过该对象调用事件属性,使用函数表达式的方式把函数委托给事件:

代码示例:

运行结果:

除了函数表达式外也可以使用函数声明的方式,把函数的名称赋值给元素对象的事件属性,注意不能写上():

代码示例:

运行结果:

第三种方式,通过addEventListener函数添加一个事件监听器,需要传递事件的名称,和函数对象,函数对象可以是函数的名称,也可以是直接写一个函数上去:

代码示例:

运行结果:

同一个元素对象的同一个事件,可以添加多个函数,这些函数可以执行不同的内容,例如我在一个button元素的mouseover事件中分别添加了三个函数,这三个函数各自打印了一句话,那么当我鼠标碰到按钮时,就会打印出三句话:

代码示例:

运行结果:

addEventListener函数还有一个布尔参数,这个参数定义着父元素和子元素重叠并且都有委托事件的情况时,是先触发父元素的事件还是先触发子元素的事件,参数值为true是定义先触发父元素的事件,参数值为false则是定义先触发子元素的事件,不定义这个参数的话,默认情况下是先触发子元素的事件。

父元素和子元素重叠情况,不定义addEventListener函数布尔值的代码示例:

运行结果:

父元素和子元素重叠情况,定义addEventListener函数布尔值为true的代码示例:

运行结果:

还有一种情况就是父元素和子元素不完全重叠,这种情况下不定义addEventListener函数的布尔值,当鼠标移动到子元素时先触发父元素的事件,然后移出子元素时先触发子元素的事件再触发父元素的事件,这是因为默认情况下子元素的事件先执行,所以父元素的事件不会连续执行。

定义addEventListener函数的布尔值为true的话,当鼠标移动到子元素时先触发父元素的事件,然后移出子元素时还是触发父元素的事件,最后才触发子元素的事件,这是因为布尔值为true的情况下父元素的事件先执行,所以父元素的事件会连续执行。

父元素和子元素不完全重叠的情况,不定义addEventListener函数布尔值的代码示例:

运行结果:

父元素的事件不会连续执行

父元素和子元素不完全重叠的情况,定义addEventListener函数布尔值为true的代码示例:

运行结果: 父元素的事件会连续执行

事件源 Even: 事件源,就是事件产生时的信息收集,可以通过事件源对象获得很多相关数据,可以设置元素的属性,以下是常见的事件源对象属性:

通过事件源对象调用target属性设置元素的背景颜色代码示例:

运行结果:

以上只使用到了鼠标事件中的mouseout和mouseover事件,事件还有很多,以下是常见事件的分类思维导图:

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

推荐阅读更多精彩内容

  • 事件处理程序在应用中是必不可少的,虽然现在很多框架都有自己实现事件处理方法,但是熟知原生才能让我们应对各种各样的需...
    俗三疯阅读 283评论 0 1
  • 基本概念 事件是一些特定动作发生时所发出的信号,JavaScript中的事件是可以被 JavaScript 侦测到...
    Zd_silent阅读 449评论 0 1
  • JavaScript事件是由访问Web页面的用户引起的一系列操作,例如:用户点击。当用户执行某些操作的时候,再去执...
    轻思维阅读 427评论 0 7
  • 一、事件的添加方式 on的方式:此方法给同一元素绑定两次事件,前面的事件会被覆盖,事件处理机制为事件冒泡。 如:d...
    XZ阳光小熊阅读 654评论 0 2
  • 清心写作训练30天第5天 女孩全身痉挛,痛苦不堪,她就是携带丧尸病毒携带者,只见她死去后突然醒来,瞳也变成了灰色,...
    芷水中银三星阅读 492评论 2 4