广告
返回顶部
首页 > 资讯 > 精选 >如何在javascript中实现异步
  • 468
分享到

如何在javascript中实现异步

2023-06-15 09:06:07 468人浏览 泡泡鱼
摘要

本篇文章给大家分享的是有关如何在javascript中实现异步,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。方法:1、利用setTimeout;2、利用setImmediate

本篇文章给大家分享的是有关如何在javascript中实现异步,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

方法:1、利用setTimeout;2、利用setImmediate;3、利用requestAnimationFrame;4、通过监听“new Image”加载状态来实现;5、通过监听script加载状态来实现;6、利用Message等等。

原生javascript实现异步的方式:

1、setTimeout:这个是最简单的

setTimeout( function() {    console.log(1);});console.log(2);

2、setImmediate :IE10添加的新功能,专门用于解放ui线程。IE10以下及其他浏览器不支持

setImmediate(function(){    console.log(1);});console.log(2);

3、requestAnimationFrame :HTML5/CSS3时代新产物,专门用于动画。低级浏览器不支持

var asynByAniFrame = (function(){    var _window = window,    frame = _window.requestAnimationFrame            || _window.WEBkitRequestAnimationFrame            || _window.mozRequestAnimationFrame            || _window.oRequestAnimationFrame            || _window.msRequestAnimationFrame;    return function( callback ) { frame( callback ) };})();asynByAniFrame(function(){    console.log(1);})console.log(2);

4、监听new Image加载状态:通过加载一个data:image数据格式的图片,并监听器加载状态实现异步。

  尽管部分浏览器不支持data:image图片数据格式,但仍然可以触发其onerror状态实现异步,但IE8及以下对data:image数据格式的图片,onerror为同步执行

function asynByImg( callback ) {    var img = new Image();    img.onload = img.onerror = img.onreadystatechange = function() {        img = img.onload = img.onerror = img.onreadystatechange = null;        callback();     }    img.src = "data:image/png,";}asynByImg(function(){    console.log(1);});console.log(2);

5、监听script加载状态

  原理同new Image是一样的,生成一个data:text/javascript的script,并监听其加载状态实现异步。

  尽管部分浏览器不支持data:text/javascript格式数据的script,但仍然可以触发其onerror、onreadystatechange事件实现异步。

var asynByScript = (function() {    var _document = document,        _body = _document.body,        _src = "data:text/javascript,",        //异步队列        queue = [];    return function( callback ) {            var script = _document.createElement("script");            script.src  = _src;            //添加到队列            queue[ queue.length ] = callback;            script.onload = script.onerror = script.onreadystatechange = function () {                script.onload = script.onerror = script.onreadystatechange = null;                _body.removeChild( script );                script = null;                //执行并删除队列中的第一个                queue.shift()();            };            _body.appendChild( script );        }    })();asynByScript( function() {    console.log(1);} );console.log(2);

6、Message:html5新技能,通过监听window.onmessage事件实现,然后postMessage发送消息,触发onmessage事件实现异步

var asynByMessage = (function() {        //异步队列        var queue = [];        window.addEventListener('message', function (e) {            //只响应asynByMessage的召唤            if ( e.data === 'asynByMessage' ) {                e.stopPropagation();                if ( queue.length ) {                    //执行并删除队列中的第一个                    queue.shift()();                }            }        }, true);        return function( callback ) {            //添加到队列            queue[ queue.length ] = callback;            window.postMessage('asynByMessage', '*');        };    })();asynByMessage(function() {    console.log(1);});console.log(2);

7、Promise: ES6的新技能,具有异步性质

var asynByPromise = (function() {        var promise = Promise.resolve({                then : function( callback ) {                    callback();                }            });        return function( callback ) {                    promise.then(function(){                        callback();                    })                };    })();asynByPromise(function() {    console.log(1);});console.log(2);

以上就是如何在javascript中实现异步,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网精选频道。

--结束END--

本文标题: 如何在javascript中实现异步

本文链接: https://www.lsjlt.com/news/279429.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何在javascript中实现异步
    本篇文章给大家分享的是有关如何在javascript中实现异步,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。方法:1、利用setTimeout;2、利用setImmediate...
    99+
    2023-06-15
  • 怎么在JavaScript中实现同步和异步
    本篇文章为大家展示了怎么在JavaScript中实现同步和异步,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的...
    99+
    2023-06-14
  • 怎么在Javascript中实现异步等待
    本篇文章给大家分享的是有关怎么在Javascript中实现异步等待,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。async/await 是javascript中的一种模式,可使...
    99+
    2023-06-15
  • ES6中javascript如何实现异步操作
    这篇文章主要为大家展示了“ES6中javascript如何实现异步操作”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ES6中javascript如何实现异步操作...
    99+
    2022-10-19
  • JavaScript如何实现异步调用
    小编给大家分享一下JavaScript如何实现异步调用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!问题可修改下面的 aa() ...
    99+
    2022-10-19
  • 如何实现JavaScript异步回调
    JavaScript是一门单线程语言,即每一次只能执行一个任务。这意味着在某些情况下,如果我们直接在JavaScript中调用一个可能会花费很长时间的函数,页面会因此被冻结并无法响应。为了解决这个问题,我们需要使用异步回调,让JavaScr...
    99+
    2023-05-14
  • 如何在 JavaScript 中实现高效的异步编程模式?
    JavaScript 是一门非常流行的编程语言,它的异步编程模式是其最大的特点之一。JavaScript 中的异步编程模式可以帮助我们在处理 I/O 操作和网络请求时提高程序的性能。本文将介绍如何在 JavaScript 中实现高效的异步编...
    99+
    2023-10-02
    异步编程 javascript linux
  • 如何在 PHP 中实现基于 HTTP 的异步 JavaScript 调用?
    在现代的 Web 开发中,异步调用变得越来越普遍。而在 PHP 开发中,我们常常需要与 JavaScript 进行交互。本文将介绍如何在 PHP 中实现基于 HTTP 的异步 JavaScript 调用。 什么是异步调用? 在传统的同步调用...
    99+
    2023-11-06
    http apache javascript
  • 如何在Go和JavaScript中实现高效的异步编程?
    异步编程是现代编程中的重要组成部分,它允许我们在等待某些操作完成时执行其他代码。在Go和JavaScript中,有许多方法可以实现高效的异步编程。在本文中,我们将探讨这些方法并演示一些示例代码。 Goroutines和Channels ...
    99+
    2023-09-26
    javascript 异步编程 http
  • 异步编程如何在ASP中实现?
    随着互联网的不断发展,越来越多的网站和应用程序需要处理大量的请求,这就需要我们采用一些高效的编程方式来提高程序的性能和响应速度。其中异步编程就是一种非常有效的方式,本文将介绍如何在ASP中实现异步编程。 什么是异步编程? 异步编程是指一种...
    99+
    2023-09-12
    异步编程 面试 windows
  • 如何在Java中实现异步编程?
    在Java编程中,异步编程是一种非常重要的技能,它可以让你的程序更高效地利用系统资源,提高程序的性能和响应速度。本文将介绍如何在Java中实现异步编程,让你的程序更加高效。 什么是异步编程? 在传统的同步编程中,程序的每一步都是按照顺序...
    99+
    2023-11-11
    异步编程 自然语言处理 学习笔记
  • 在PHP中如何实现异步编程?
    在PHP中如何实现异步编程?随着Web应用程序的不断发展,用户对程序的交互性和响应性要求越来越高。异步编程可以有效地提高程序的性能和响应速度,为用户带来更好的体验。本文将介绍在PHP中如何实现异步编程。一、什么是异步编程?简单来说,异步编程...
    99+
    2023-05-14
    PHP 实现 异步编程
  • javascript怎么实现异步
    JavaScript是一门常用的编程语言,被广泛应用于web开发、游戏开发等领域。在JavaScript编程中,异步编程是一项重要的技术,它能够提高程序的性能和响应速度。那么,JavaScript怎样实现异步编程呢?本篇文章将从以下方面进行...
    99+
    2023-05-20
  • 如何在python中实现异步非阻塞
    这篇文章给大家介绍如何在python中实现异步非阻塞,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、说明当一个异步过程调用发出后,调用者不会立刻得到结果。实际处理这个调用的部件是在调用发出后,通过状态、通知来通知调用...
    99+
    2023-06-15
  • 如何在PHP异步编程中实现Spring API?
    在PHP异步编程中实现Spring API是一项复杂的任务,但是,如果您掌握了正确的技巧和工具,这项任务将变得更加容易。在本文中,我们将介绍如何使用PHP实现Spring API,并演示一些代码示例。 首先,我们需要了解什么是Spring ...
    99+
    2023-10-04
    异步编程 spring api
  • NumPy 和异步编程:如何在 Python 中实现?
    NumPy 是一个 Python 库,用于支持大规模多维数组和矩阵运算。它是 Python 科学计算的核心库之一,为数据科学家、工程师和研究人员提供了一种高效的方法来处理数字数据。 异步编程是一种流行的编程模式,可以实现高性能的并发操作。...
    99+
    2023-07-22
    numy 异步编程 npm
  • 如何在 Laravel 中实现高效异步编程?
    Laravel 是一个流行的 PHP Web 开发框架,它提供了许多强大的工具和功能,使得开发者可以快速构建高质量的 Web 应用程序。在这篇文章中,我们将探讨如何在 Laravel 中实现高效异步编程。 什么是异步编程? 在传统的同步编程...
    99+
    2023-10-20
    关键字 异步编程 laravel
  • 如何在PHP开发中实现异步编程?
    PHP是一种流行的服务器端编程语言,它通常用于构建Web应用程序。在许多情况下,我们需要处理大量的并发请求,这时候异步编程就显得尤为重要。本文将介绍如何在PHP开发中实现异步编程,并提供一些示例代码。 一、什么是异步编程? 异步编程是一种编...
    99+
    2023-07-21
    开发技术 容器 异步编程
  • 详解JavaScript实现异步Ajax
    目录一、什么是 AJAX ?1、AJAX是基于现有的Internet标准2、AJAX 工作原理二、AJAX - 创建 XMLHttpRequest 对象1、XMLHttpReques...
    99+
    2022-11-13
  • javascript实现异步的方法
    这篇文章给大家分享的是有关javascript实现异步的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。javascript实现异步的方法:1、使用setTimeout方法;2、使用setImmediate 方...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作