javascript自定义事件功能与用法实例分析
作者:目尽地平线 发布时间:2024-07-17 17:55:15
本文实例讲述了javascript自定义事件功能与用法。分享给大家供大家参考,具体如下:
概述
自定义事件很难派上用场?
为什么自定义事件很难派上用场,因为以前js不是模块化开发,也很少协作。因为事件本质是一种通信方式,是一种消息,只有存在多个对象,多个模块的情况下,才有可能需要用到事件进行通信。而现在有了模块化之后,已经可以使用自定义事件进行各模块间协作了。
哪里用得到自定义事件?
事件本质是一种消息,事件模式本质上是观察者模式的实现,那么用得上观察者模式的地方,自然也可以也可以用上事件模式。所以,如果:
1、一个目标对象改变,需要多个观察者调整自身的。
比如:我需要元素A点击之后,元素B显示鼠标的位置,元素C显示提示,元素D.....
2、分模块协作需要解耦的
比如:甲负责模块A,乙负责模块B,模块B需要A运行完之后才能运行
传统的写法将逻辑写在一个方法里面:
function doSomething(){
A();
B();
}
这样做每次扩展都要修改a的点击函数,不好扩展。
自定义事件的写法
//1、创建事件
var clickElem = new Event("clickElem");
//2、注册事件 *
elem.addEventListener("clickElem",function(e){
//干点事
})
//3、触发事件
elem.dispatchEvent(clickElem);
可以看到,elem通过dispatchEvent方法触发的事件,只有elem上注册的 * 才能监听得到。这就很没意思了,自己发给自己消息,通知自己去干什么。
创建自定义事件可参考: MDN : Creating_and_triggering_events
应用
从前面 js 自定义事件 的描述中知道:元素A通过dispatchEvent方法触发的事件,只有A上注册的 * 才能监听得到。
我们想要的效果是,别的对象干了某件事之后, 发个消息给我们,好让我们能做相应的改变。要做到这样,也不是没办法:我们可以在一个公共对象上监听和触发事件,这就很有意义了。
例子一:通知多个对象
要实现 元素A点击之后,元素B显示鼠标的位置,元素C显示提示,可以这样写:
文件:a.js
import b from "./b"
import c from "./c"
var a = document.getElementById("a");
a.addEventListener("click",function(e){
var clickA = new Event("clickA");
document.dispatchEvent(clickA);
});
注意:import进来的变量虽然不使用,但是一定不能省略
文件b.js:
var b = document.getElementById("b");
document.addEventListener("clickA",function(e){
b.innerHTML = "(128,345)";
})
文件c.js:
var c = document.getElementById("c");
document.addEventListener("clickA",function(e){
c.innerHTML = "你点了A";
})
这样写,三个模块之间完全不用关心对象,也不知道对方存在,耦合度非常的低,完全可以独立编写,不会互相影响。这其实就是一个观察者模式的实现。
例子二:游戏框架
要开发一个游戏,启动游戏,加载图片和音乐,加载完后,渲染场景和音效,加载和渲染由不同的人负责。可以这样写:
文件:index.js
import loadImage from "./loadImage"
import loadMusic from "./loadMusic"
import initScene from "./initScene"
var start = document.getElementById("start");
start.addEventListener("click",function(e){
console.log("游戏开始!");
document.dispatchEvent(new Event("gameStart"));
})
文件:loadImage.js
// 加载图片
document.addEventListener("gameStart",function(){
console.log("加载图片...");
setTimeout(function(){
console.log("加载图片完成");
document.dispatchEvent(new Event("loadImageSuccess"));
},1000);
});
文件:loadMusic.js
//加载音乐
document.addEventListener("gameStart",function(){
console.log("加载音乐...");
setTimeout(function(){
console.log("加载音乐完成");
document.dispatchEvent(new Event("loadMusicSuccess"));
},2000);
});
文件:initScene.js
//渲染场景
document.addEventListener("loadImageSuccess",function(e){
console.log("使用图片创建场景...");
setTimeout(function(){
console.log("创建场景完成");
},2000)
});
//渲染音效
document.addEventListener("loadMusicSuccess",function(e){
console.log("使用音乐创建音效...");
setTimeout(function(){
console.log("创建音效完成");
},500)
});
加载模块和渲染模块互不影响,易于扩展。
携带信息
除此之外,事件还能传递自定义信息:
var event = new CustomEvent('myEvent', { 'dataName': dataContent });
document.dispatchEvent(event);
(注意:传递自定义信息需要使用CustomEvent,而不是Event)
然后在监听函数里取出:
document.addEventListener("myEvent",function(e){
console.log(e.dataName);
})
这个功能非常有用!
希望本文所述对大家JavaScript程序设计有所帮助。
来源:http://blog.csdn.net/ruangong1203/article/details/52474452


猜你喜欢
- 简介主要是尝试简单的使用pyhton的爬虫功能,于是使用有道进行尝试,并没有进行深入的诸如相关api的调用。以下是需要的POST数据代码以下
- class pygame.Rect Rect对象的属性:Rect 表示的区域必须位于一个 Surface 对象之上,比如游戏的主窗口(scr
- 本文以实例形式分析了Python多进程编程技术,有助于进一步Python程序设计技巧。分享给大家供大家参考。具体分析如下:一般来说,由于Py
- 创建一个软件包(package)似乎已经足够简单了,也就是在文件目录下搜集一些模块,再加上一个__init__.py文件,对吧?我们很容易看
- Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM Select
- 正则表达式处理花括号内容替换赋值@Test public void replaceStr() { &
- 优雅的设计经常包含一些特殊的字体,而这些字体并不存在于用户的字体库中,我们并不能奢求每一个访客都是设计师。 :-)虽然CSS3标
- TEMPLATESDjango 1.8的新特性一个列表,包含所有在Django中使用的模板引擎的设置。列表中的每一项都是一个字典,包含某个引
- asp之家注:也许你还没有接触过使用js来调用asp文件,也许你也不知道如何用JS调用asp文件,甚至你也不知道JS调用asp文件有什么好处
- 本文实例讲述了Python自动发送邮件的方法。分享给大家供大家参考,具体如下:python发邮件需要掌握两个模块的用法,smtplib和em
- paramiko模块提供了ssh及sft进行远程登录服务器执行命令和上传下载文件的功能。这是一个第三方的软件包,使用之前需要安装。1 基于用
- 本系列教程我们将使用python实现一些简单的测试工具,为了尽可能的简单,我们的工具以命令行工具为主。本系列教程使用的python版本是3.
- 最近公司在研发app,选择了基于Vue框架的vux组件库,现总结在实现上拉刷新功能遇到的坑:1.问题:只刷新一次,解决方法:需要自己手动重置
- 本文实例讲述了Python读写ini文件的方法。分享给大家供大家参考。具体如下:比如有一个文件update.ini,里面有这些内容:[ZIP
- 效果图:图(1) 原始图图(2) 缩小后图(3) 放大后代码如下:<!DOCTYPE html><html> <
- 所使用python环境为最新的3.6版本一、安装pdfminer模块 安装anaconda后,直接可以通过pip安装pip install
- 通常情况下,定义函数时都会选择有参数的函数形式,函数参数的作用是传递数据给函数,令其对接收的数据做具体的操作处理。在使用函数时,经常会用到形
- 题目描述原题链接 :268. 丢失的数字给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0
- 公司做了个客户,需要图片生成像alibaba的效果。原来开发的系统都是用Aspjpeg进行缩小图的,现在需要处理图片,当然又想到这个组件。但
- 利用序列产生主键值。 序列(Sequence)是一种可以被多个用户使用的用于产生一系列唯一数字的数据库对象。序列定义存储在数据字典中,通过提