返回顶部
首页 > 资讯 > 前端开发 > html >web中异步编程的方式有哪些
  • 595
分享到

web中异步编程的方式有哪些

2024-04-02 19:04:59 595人浏览 薄情痞子
摘要

本篇内容主要讲解“WEB中异步编程的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web中异步编程的方式有哪些”吧!回调函数因为 f1 是一个需要一定

本篇内容主要讲解“WEB中异步编程的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web中异步编程的方式有哪些”吧!

回调函数

因为 f1 是一个需要一定时间的函数,所以可以将 f2 写成 f1 的回调函数,将同步操作变成异步操作,f1 不会阻塞程序的运行,f2 也无需空空等待,例如 Jqueryajax

回调函数的demo:

function f1(f2){
    setTimeout(function(){
        console.log('先执行 f1')
    },1000)
    f2()
}function f2() {
    console.log('再执行 f2')
}

效果如下:
web中异步编程的方式有哪些

总结:回调函数易于实现、便于理解,但是多次回调会导致代码高度耦合

事件监听

脚本的执行不取决代码的顺序,而取决于某一个事件是否发生。

事件监听的demo

$(document).ready(function(){     console.log('DOM 已经 ready')
});

发布订阅模式

发布/订阅模式是利用一个消息中心,发布者发布一个消息给消息中心,订阅者从消息中心订阅该消息,。类似于 Vue 的父子组件之间的传值。

发布订阅模式的 demo

//订阅done事件$('#app').on('done',function(data){    console.log(data)
})//发布事件$('#app').trigger('done,'haha')

Promise

Promise 实际就是一个对象, 从它可以获得异步操作的消息,Promise 对象有三种状态,pending(进行中)、fulfilled(已成功)和rejected(已失败)。Promise 的状态一旦改变之后,就不会在发生任何变化,将回调函数变成了链式调用。

Promise 封装异步请求demo

export default function getMethods (url){    return new Promise(function(resolve, reject){
        axiOS.get(url).then(res => {
            resolve(res)
        }).catch(err =>{
            reject(err)
        })
    })
}
getMethods('/api/xxx').then(res => {    console.log(res)
}, err => {    console.log(err)
})

Generator

Generator 函数是一个状态机,封装了多个内部状态。执行 Generator 函数会返回一个遍历器对象,使用该对象的 next() 方法,可以遍历 Generator 函数内部的每一个状态,直到 return 语句。

形式上,Generator 函数是一个普通函数,但是有两个特征。一是,function关键字与函数名之间有一个星号;二是,函数体内部使用yield表达式, yield是暂停执行的标记。

next() 方法遇到yield表达式,就暂停执行后面的操作,并将紧跟在yield后面的那个表达式的值,作为返回的对象的value属性值。

Generator 的 demo

function *generatorDemo() {  yield 'hello';  yield  1 + 2;  return 'ok';
}
var demo = generatorDemo()
demo.next()   // { value: 'hello', done: false } 
demo.next()   // { value: 3, done: false } 
demo.next()   // { value: 'ok', done: ture } 
demo.next()   // { value: undefined, done: ture }

async

async函数返回的是一个 Promise 对象,可以使用 then 方法添加回调函数,async 函数内部 return 语句返回的值,会成为 then 方法回调函数的参数。当函数执行的时候,一旦遇到await就会先返回,等到异步操作完成,再接着执行函数体内后面的语句。

1.await命令后面返回的是 Promise 对象,运行结果可能是rejected,所以最好把await命令放在try...catch代码块中。

async 的 demo1

async function demo() {  try {    await new Promise(function (resolve, reject) {      // something
    });
  } catch (err) {    console.log(err);
  }
}
demo().then(data => {    console.log(data)  // })

到此,相信大家对“web中异步编程的方式有哪些”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: web中异步编程的方式有哪些

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

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

猜你喜欢
  • web中异步编程的方式有哪些
    本篇内容主要讲解“web中异步编程的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web中异步编程的方式有哪些”吧!回调函数因为 f1 是一个需要一定...
    99+
    2024-04-02
  • javascript异步编程有哪些方式
    这篇文章主要为大家展示了“javascript异步编程有哪些方式”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript异步编程有哪些方式”这篇文章吧...
    99+
    2024-04-02
  • java异步编程有哪些方式
    本篇内容介绍了“java异步编程有哪些方式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!为什么需要异步?操作系统可以看作是个虚拟机(VM),...
    99+
    2023-06-15
  • java异步编程的实现方式有哪些
    这篇文章主要介绍“java异步编程的实现方式有哪些”,在日常操作中,相信很多人在java异步编程的实现方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java异步编程的实现方式有哪些”的疑惑有所帮助!...
    99+
    2023-07-05
  • Java异步非阻塞编程的方式有哪些
    这篇文章主要讲解了“Java异步非阻塞编程的方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java异步非阻塞编程的方式有哪些”吧!1 服务端执行,最简单的同步调用方式:缺陷:服务端...
    99+
    2023-06-20
  • Java异步编程API的打包方式有哪些?
    Java异步编程是现代软件开发中非常重要的一部分,它可以帮助我们提高程序的性能和响应速度。在Java中,异步编程API有很多种不同的打包方式,本文将为您介绍其中几种常见的打包方式,并附上相应的演示代码。 CompletableFuture...
    99+
    2023-08-28
    异步编程 api 打包
  • JS异步编程有哪些方案
    这篇文章主要讲解了“JS异步编程有哪些方案”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JS异步编程有哪些方案”吧!关于 JS 单线程、EventLoop ...
    99+
    2024-04-02
  • JS异步编程方案有哪些
    本篇内容主要讲解“JS异步编程方案有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JS异步编程方案有哪些”吧!一、同步与异步我们可以通俗理解为异步就是一个任...
    99+
    2024-04-02
  • Java和Bash:缓存的异步编程方式有哪些?
    在软件开发领域中,缓存是一种非常重要的技术。缓存可以提高程序的性能,减少对于后端服务的访问次数,从而缩短响应时间,提高用户体验。但是,缓存的使用也带来了一些问题,比如缓存的一致性、缓存的更新和失效等等。为了解决这些问题,我们需要使用异步编...
    99+
    2023-06-28
    bash 缓存 异步编程
  • javascript中实现异步编程的方法有哪些
    javascript中实现异步编程的方法有哪些?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。javascript异步编程的4种方法:1、回调函数,这是异步编程最...
    99+
    2023-06-14
  • 异步编程中索引重定向的实现方式有哪些?
    异步编程是现代编程语言中的热门话题,它可以提高应用程序的性能和响应能力。但是,异步编程也带来了一些问题,其中之一就是索引重定向。当我们在执行异步操作时,可能会需要对一个索引进行操作,但是由于异步操作的特性,索引可能会在操作完成前发生变化,...
    99+
    2023-11-13
    索引 重定向 异步编程
  • PHP编程中常用的异步编程算法有哪些?
    随着互联网技术的不断发展,Web应用程序对并发性和响应性的需求越来越高。异步编程成为了一种解决方案,因为它可以充分利用现代计算机的多核心和并行处理能力,提高Web应用程序的性能和响应速度。在PHP编程中,异步编程也变得越来越重要。本文将介...
    99+
    2023-10-29
    编程算法 api 异步编程
  • PHP 异步编程技术有哪些?
    php 异步编程技术指南有下列主要方法:reactphp:事件驱动的库,提供事件循环和反应式扩展。amphp:基于协程的库,使用生成器函数和协程进行异步编程。guzzle psr7:用于...
    99+
    2024-05-06
    php 异步编程 并发请求 swoole
  • JavaScript异步处理的方式有哪些
    这篇“JavaScript异步处理的方式有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇...
    99+
    2024-04-02
  • 文件操作:PHP和NumPy的异步编程实现方式有哪些?
    在当今的计算机科学领域中,异步编程已经成为一个非常重要的话题。异步编程是一种编程方式,它允许程序在等待某些操作完成的同时,可以继续执行其他任务。这种编程方式可以提高程序的并发性和响应速度,特别是在文件操作等I/O密集型任务中。在本文中,我...
    99+
    2023-10-05
    numpy 异步编程 文件
  • ASP异步编程中的分布式索引优化技巧有哪些?
    ASP异步编程是一种高效的编程方式,可以极大地提高程序的并发处理能力。在这种编程模型中,分布式索引优化技巧是非常重要的,可以帮助我们更好地利用分布式架构提高程序的效率。本文将介绍ASP异步编程中的分布式索引优化技巧,并且给出相应的演示代码...
    99+
    2023-10-19
    分布式 异步编程 索引
  • 处理异步事件的方式有哪些
    本篇内容介绍了“处理异步事件的方式有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!同步异步首先当然要先...
    99+
    2024-04-02
  • Go语言中有哪些支持异步编程的包?
    Go语言是一门非常流行的编程语言,它的高效性和简洁性使得越来越多的程序员选择使用它来开发应用程序。在Go语言中,异步编程是一种非常流行的编程方式。异步编程可以提高程序的性能和响应速度,使得程序能够更好地应对高并发的情况。本文将介绍一些Go语...
    99+
    2023-06-25
    实时 异步编程 npm
  • 掌握Node.js中的Promise异步编程方式
    目录介绍 静态方法Promise.resolve()Promise.allPromise.allsSettled介绍  Promise就是一个用来存储数据的对象但...
    99+
    2023-05-18
    Node.js Promise Node.js Promise异步编程
  • Java中异步转同步的方法有哪些
    今天小编给大家分享一下Java中异步转同步的方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、问题应用场景应用中通...
    99+
    2023-07-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作