前言

JavaScript是一种事件驱动型语言。事件驱动是指JavaScript引擎并不是在看到代码之后就会立即执行,而是会在合适的时间才去执行。这个合适的时间是指当某个事件发生之后(例如一个输入框的内容发生了变化,这就是一个事件)。只有当相应的事件发生了之后,相应的操作才会执行,这就是事件驱动。

事件驱动包含三个关键内容:事件、事主和处理方法。

理解了事件模型,我们就能明白JavaScript中的代码虽然是用于描述怎么操作对象的,但是并不一定要立即操作对象。

事件基础、事件侦听与抛发

js事件分为系统事件和自定义派发事件。

IE8以上支持

  • DOM.addEventListener(事件类型,事件回调函数);

    事件侦听方法,仅用于仅用于EventTarget对象,给DOM元素添加一个事件侦听(监听),只能收到对应事件类型的消息,当收到这个消息。就执行事件回调函数。


//这里click这个消息就是系统消息,clickHandler,就是这个系统消息收到后,执行的事件回调函数。
document.addEventListener("cilck",clickHandler);
/**
事件回调函数
e 有且仅有一个参数e
e 是一个事件对象,侦听事件收到的消息时获得的事件对象
*/
function clickHandler(e){
console.log(e);
}
  • EventTarget.dispatchEvent(事件对象);

    抛发事件方法,派发事件,仅用于EventTarget对象

    //这里的“myClick”,就是自定义事件类型,是事件传输的“暗号”。
document.addEventListener("myClick",myClickHandler); var evt = new Event("myClick");//创建一个事件对象
evt.a=10;
document.dispatchEvent(evt);//向document抛发新建的event事件,抛发事件关键是将新建事件的参数传输出来 function myClickHandler(e){
console.log(e===evt);//true
console.log(e.a);//10,接收到了派发事件对象的参数
}

总结

  1. 事件必须先侦听后抛发。
  2. 侦听和派发的对象是同一个。
  3. 侦听和派发的事件类型完全相同。其实事件类型就是一个任意字符串
  4. 系统派发的事件字符串是固定的,自定义派发的事件,字符串可以任意
  5. 事件侦听回调函数,不能传参,因此事件回调函数中有且仅有一个参数,这个参数即为事件对象
  6. 事件都可以手动派发,手动派发的话,页面加载完后就会执行

案例

对象间数据传递, 打算执行obj2.c 将局部变量5传递给obj1的方法b中

要求:使程序模块的可重用性、移植性大大增强。一个好的内聚模块应当恰好做一件事。

obj1 和 obj2 互相调用,但是不相互影响,删除任意一个函数后,也不会报错。

// 高内聚低耦合
var obj1={
a:function(){
// this 对象的方法中this就是该对象自身,这里this就是obj1
document.addEventListener("aaa",this.b);
},
b:function(e){
// 传到这里
console.log(e.s);//5
}
} var obj2={
v:10,
c:function(){
var s=5;
var evt=new Event("aaa");
evt.s=s;
document.dispatchEvent(evt);
},
d:function(){
//......
} } obj1.a();//注册事件
obj2.c();//创建事件,并且把这个事件抛发出去

JS 的事件基础、事件侦听与抛发、的更多相关文章

  1. stopImmediatePropagation和stopPropagation (事件、防止侦听)

    参考: ActionScript 3.0 Step By Step系列(六):学对象事件模型,从点击按扭开始 actionscript宝典 一.事件模型 egret中的事件模型和flash是一样的,但 ...

  2. Vue.js 源码分析(七) 基础篇 侦听器 watch属性详解

    先来看看官网的介绍: 官网介绍的很好理解了,也就是监听一个数据的变化,当该数据变化时执行我们的watch方法,watch选项是一个对象,键为需要观察的数据名,值为一个表达式(函数),还可以是一个对象, ...

  3. Js 事件基础

    一:js中常见得事件 (1) : 鼠标事件         click :点击事件         dblclick :双击事件         contextmenu : 右键单击事件        ...

  4. vue02 过滤器、计算和侦听属性、vue对象的生命周期、阻止事件冒泡和刷新页面

    3. Vue对象提供的属性功能 3.1 过滤器 过滤器,就是vue允许开发者自定义的文本格式化函数,可以使用在两个地方:输出内容和操作数据中. 定义过滤器的方式有两种. 3.1.1 使用Vue.fil ...

  5. js事件流、事件处理程序/事件侦听器

    1.事件流 事件冒泡 IE的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到较为不具体的节点(文档). 事件捕获 ...

  6. js基础——事件绑定(事件监听)

    JavaScript事件一共有三种监听方法分别如下: 1.事件监听一夹杂在html标签内 <div id="box" onClick="alert('HELLO W ...

  7. Node.js 教程 05 - EventEmitter(事件监听/发射器 )

    目录: 前言 Node.js事件驱动介绍 Node.js事件 注册并发射自定义Node.js事件 EventEmitter介绍 EventEmitter常用的API error事件 继承EventEm ...

  8. JavaScript DOM高级程序设计 4.3控制事件流和注册事件侦听器--我要坚持到底!

    一.事件流 我们通过下面一个实例,进行说明. <body> <h1>Event Flow</h1> <ul id="nav"> &l ...

  9. Android事件侦听器回调方法浅谈

    http://developer.51cto.com/art/201001/180846.htm Android事件侦听器作为视图View类的接口,其中包含有不少回调方法,比如:onClick():o ...

随机推荐

  1. 搭建XSS测试平台

    XSS测试平台是测试XSS漏洞获取cookie并接收web页面的平台,XSS可以做js能做的所有事情,包括但不限于窃取cookie,后台增删文章.钓鱼.利用xss漏洞进行传播.修改网页代码.网站重定向 ...

  2. Django 缓存机制

    一 缓存介绍 在动态网站中,用户所有的请求,服务器都会去数据库中进行相应的增,删,查,改,渲染模板,执行业务逻辑,最后生成用户看到的页面. 当一个网站的用户访问量很大的时候,每一次的的后台操作,都会消 ...

  3. coding++:Spring中的@Transactional(rollbackFor = Exception.class)属性详解

    异常: 如下图所示,我们都知道 Exception 分为 运行时异常 RuntimeException 和 非运行时异常. error 是一定会回滚的. 如果不对运行时异常进行处理,那么出现运行时异常 ...

  4. 【LeetCode】15.三数之和

    题目描述 1. 三数之和 给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有满足条件且不重复的三元组. 注意: ...

  5. Selenium系列(二十) - PageObject模式的详细介绍

    如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...

  6. Ubuntu16.04下LAMP环境的安装与配置

    Ubuntu16.04下LAMP环境的安装与配置 最近做个实验需要用到Ubuntu环境的靶场,所以这里介绍下Ubuntu环境下LAMP的安装与配置,话不多说,我们gkd! 1.Apache2的安装 首 ...

  7. 【nodejs 爬虫】使用 puppeteer 爬取链家房价信息

    使用 puppeteer 爬取链家房价信息 目录 使用 puppeteer 爬取链家房价信息 页面结构 爬虫库 pupeteer 库 实现 打开待爬页面 遍历区级页面 方法一 方法二 遍历街道页面 遍 ...

  8. 前端经典面试题解密:JS的new关键字都干了什么?

    前言 new关键字在实例化获取对象时都做了什么?是一道经常出现在前端面试时的问题.如果只是简单的了解new关键字是实例化构造函数获取对象,是万万不能够的.更深入的层级发生了什么呢?同时面试官想从这道题 ...

  9. 怎么处理使用UINavigation(导航控制器时) UIScrollView及其子类UITableView、UICollectionView可能出现的向下偏移64Px或者顶部对齐等问题

    前言           近期在做项目时遇到了好几起由于自动偏移或则没有自动偏移而导致的界面布局问题,尤其是在昨晚新版本赶上IOS9系统升级的时候,刚升级完了后就发现项目里面很多使用UINavgati ...

  10. LinuxNFS网络文件系统

    LinuxNFS网络文件系统 首先需要准备四台机器,分别为以下服务器 NAS-Server-0 IP:192.168.254.10 Web-Server-1 IP:192.168.254.11 Web ...