深入理解JavaScript事件机制

 更新时间:2023年04月21日 10:34:11   作者:叶落风尘  
事件机制是几乎所有开发语言都有的机制,并不是deviceone的独创,在某些语言称之为消息(Event),有些地方称之为(Message).接下来通过本文给大家介绍JS事件机制的理解 ,需要的朋友一起学习吧

如何实现一个事件的发布订阅

可以通过以下步骤实现 JavaScript 中的发布-订阅模式:

创建一个事件管理器对象。

const eventManager = {
  events: {},
  subscribe: function (eventName, callback) {
    if (!this.events[eventName]) {
      this.events[eventName] = [];
    }
    this.events[eventName].push(callback);
  },
  publish: function (eventName, data) {
    if (this.events[eventName]) {
      this.events[eventName].forEach(function (callback) {
        callback(data);
      });
    }
  },
};

在需要订阅或发布事件的地方使用该对象。

// 订阅事件
eventManager.subscribe('eventName', function (data) {
  console.log('收到了数据:', data);
});
// 发布事件
eventManager.publish('eventName', { name: 'test', age: 18 });

这样就可以实现 JavaScript 中的发布-订阅模式。

介绍下事件循环

JavaScript 的事件循环是一种机制,用于管理代码中异步操作的执行。它基于单线程模型,即只有一个主线程来处理所有的任务。

当 JavaScript 代码在执行时,它会将同步任务添加到调用栈中,并按照顺序依次执行,直到调用栈为空。但是,JavaScript 还支持处理异步任务,例如 HTTP 请求、定时器等等。这些异步任务不会立即返回结果,而是在某个时间点才会完成。

为了处理异步任务,JavaScript 引擎会将它们添加到任务队列中,并在调用栈为空后开始执行队列中的下一个任务。这个过程就是事件循环。事件循环通过不断地从任务队列中取出任务并执行来处理异步操作。

在事件循环中,任务被分为两类:宏任务(macrotask)和微任务(microtask)。宏任务包括事件回调、定时器回调和 I/O 操作等,而微任务则包括 Promise 的回调函数及其它一些需要立即执行的任务。当调用栈为空时,事件循环首先会执行所有已经准备好的微任务,然后再从宏任务队列中获取一个任务并执行。

宏任务和微任务的区别

在 JavaScript 中,宏任务和微任务都是异步代码执行的方式,主要体现在任务队列中。

宏任务(macrotask)通常是一些较为耗时的任务,包括整块代码的执行、setTimeout、setInterval、I/O 操作等任务。它们会被放入宏任务队列中等待执行,在每个事件循环(event loop)中,只有一个宏任务可以被执行。

微任务(microtask)通常是一些较为轻量的任务,包括 Promise 的回调函数、MutationObserver 的回调函数、async/await等,在每个宏任务执行完成后会立即执行所有微任务队列中的任务,直到队列为空。

在执行事件循环时,如果宏任务队列中有任务,就会执行宏任务队列中的第一个任务,执行完后再执行微任务队列中的所有任务。这样来回循环,直到宏任务和微任务队列中都没有任务为止。

因此,宏任务和微任务的区别在于执行顺序和优先级不同,微任务会优先于宏任务执行。这是因为微任务执行完之后可能会有一些渲染的操作,如果先执行宏任务,可能会导致页面的渲染不及时,出现页面卡顿的情况。

简单来说,宏任务在下一次事件循环时执行,而微任务在当前事件循环的末尾执行。这就意味着微任务可以更快地执行,并且可以在当前事件循环内处理一些重要的任务。

到此这篇关于深入理解JavaScript事件机制的文章就介绍到这了,更多相关JS事件机制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解微信小程序网络请求接口封装实例

    详解微信小程序网络请求接口封装实例

    这篇文章主要介绍了微信小程序网络请求接口封装,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • 细说JS数组遍历的一些细节及实现

    细说JS数组遍历的一些细节及实现

    本文主要介绍了细说JS数组遍历的一些细节及实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • 微信小程序wx.navigateTo方法里的events参数使用详情及场景

    微信小程序wx.navigateTo方法里的events参数使用详情及场景

    这篇文章主要介绍了微信小程序wx.navigateTo方法里的events参数使用详情及场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • javascript取消文本选定的实现代码

    javascript取消文本选定的实现代码

    最近在做拖动布局. 发现有文本选定的时候, 进行拖动很不好看.
    2010-11-11
  • MyEclipse取消验证Js的两种方法

    MyEclipse取消验证Js的两种方法

    通过js写一个web工程的相关页面时感觉很卡,修改内存也不行下面有两种解决方法,大家可以尝试下
    2013-11-11
  • JavaScript中的console.trace()函数介绍

    JavaScript中的console.trace()函数介绍

    这篇文章主要介绍了JavaScript中的console.trace()函数详细介绍,console.trace()函数用来打印函数调用的栈信息,需要的朋友可以参考下
    2014-12-12
  • JS动态解析多层级json数据生成html页面

    JS动态解析多层级json数据生成html页面

    在Web前端开发中,动态解析JSON数据并生成HTML页面是一项常见的任务,通过JavaScript处理多层级的JSON数据结构,不仅可以提升用户体验,还能实现灵活的内容展示和交互功能,本文将深入探讨如何使用JavaScript解析复杂的JSON数据,并将其动态渲染为HTML页面
    2025-02-02
  • electron-builder打包配置详解

    electron-builder打包配置详解

    本文主要介绍了electron-builder打包配置详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • 基于JavaScript制作霓虹灯文字 代码 特效

    基于JavaScript制作霓虹灯文字 代码 特效

    这里使用JS实现网页上的霓虹灯文字特效代码特效,运行效果看一下,你会看到文字的颜色像霓虹灯一样,连续不停变化,五颜六色的,很炫的样子,所以就叫做霓虹文字,也可以叫他文字变色效果,下面跟着小编一起学习JavaScript制作霓虹灯文字 代码特效,需要的朋友一起学习吧
    2015-09-09
  • js获取本机的外网/广域网ip地址完整源码

    js获取本机的外网/广域网ip地址完整源码

    通过js获取本机的外网和广域网ip地址的方法有很多,本文为大家介绍个不错的方法,希望对大家有所帮助
    2013-08-08

最新评论