Javascript 异步处理
1.传统异步处理
- ES6之前使用回调进行处理,示例代码:
//创建一个异步返回 双倍数值 的函数
function asyncDouble(num,cb){
// 创建标识,表示该异步处理是否完成
var complite = false
// 数值处理结果
var result = null
var timeOut = Math.random() * 3
console.log('timeOut = ',timeOut)
// 模拟异步操作
setTimeout(() => {
// 产生处理结果
result = num * 2
// 切换标识状态为完成
complite = true
},timeOut * 1000)
// 创建定时器监听异步处理是否完成
var timer = setInterval(() => {
// 根据标识判断异步处理完成,执行回调并传入处理结果
if(complite){
cb && cb(result)
clearInterval(timer)
}
},100)
}
//调用
asyncDouble(5,function(result){
console.log(result) // 10
})
2.Promise处理异步
- Promise定义:Promise是为了解决ES5中回调地狱而诞生的,Promise,顾名思义,就是承诺以后执行
- Promise创建:Promise是一个构造函数,构建示例时接收一个异步函数,创建的同时会把传入的函数执行一遍,所以需要把它封装到一个函数内部,直到函数调用时才创建promise,并执行里面的代码
- 成功与失败:传入的异步函数有2个参数(resolve,reject),成功调用resolve并把结果传递给它,失败则调用reject
//创建一个支持promise的异步方法
<script>
//封装一个支持promise的异步函数
function asyncDoubleForPromise(num){
//创建promise并返回
return new Promise(function(resolve,reject){
// 模拟异步操作
setTimeout(() => {
//判断失败还是成功
if(isNaN(num)){
//失败处理
reject()
}else{
//成功处理
resolve(num*2)
}
},1000)
})
}
</script>
- 使用then()处理异步结果:resolve对应的是then()的第一个参数,reject对应then()的第二个参数
//成功调用
asyncDoubleForPromise(5).then(res=>{
console.log(res) //10
})
//失败调用
asyncDoubleForPromise('a').then(function(res){
console.log('执行成功')
},function(){
console.log('执行失败') //执行失败
})
- 使用catch()处理失败
//失败调用
asyncDoubleForPromise('a').then(res=>{
console.log(res)
}).catch(function(){
console.log('执行失败') //执行失败
})
3.Async/await
- async和await关键字让我们可以用一种更简洁的方式写出基于Promise的异步行为,而无需刻意地链式调用promise。
- Async/await这两个关键字是成对存在的,只有在用 async 声明的function,其内部才能使用 await
- await是等待的意思,后面接收一个promise,他会一直等待promise的数据(实参)返回,然后将promise中的数据(实参)提取出来,供后面的代码处理,在此过程中,await后面的代码不会执行,处于等待状态
//实例:用async/await处理ajax请求
async function getGameList(){ //异步操作
try{
console.log('开始请求',new Date().getTime())
//axios是异步方法 await会一直等待其返回结果
const result = await axios.get('/game_list.json')
//直到axios请求结果回来,才会执行后面的代码
console.log('数据已经回来',new Date().getTime())
}catch(err){
console.log(err)
}
}
4.并发
- 通过Promise.all([promise,promise2])发起并发请求,待所有请求都回来后统一处理
<script>
new Vue({
el:"#app",
data: {
},
created(){
//直接读取返回结果
this.getAllData()
},
methods: {
getAllData(){
//接收2个promise对象
Promise.all([this.getData(), this.getData2()])
.then(function(resArr){
//返回结果放入数组中
console.log('res1',resArr[0].data)
console.log('res2',resArr[1].data)
})
},
getData(){
//返回promise对象
return axios.get('http://127.0.0.1:8086/getDouble?val=5')
},
getData2(){
//返回promise对象
return axios.get('http://127.0.0.1:8086/getTriple?val=10')
}
}
})
</script>
Javascript 异步处理的更多相关文章
- JavaScript异步编程的主要解决方案—对不起,我和你不在同一个频率上
众所周知(这也忒夸张了吧?),Javascript通过事件驱动机制,在单线程模型下,以异步的形式来实现非阻塞的IO操作.这种模式使得JavaScript在处理事务时非常高效,但这带来了很多问题,比如异 ...
- JavaScript异步编程原理
众所周知,JavaScript 的执行环境是单线程的,所谓的单线程就是一次只能完成一个任务,其任务的调度方式就是排队,这就和火车站洗手间门口的等待一样,前面的那个人没有搞定,你就只能站在后面排队等着. ...
- javascript异步编程的前世今生,从onclick到await/async
javascript与异步编程 为了避免资源管理等复杂性的问题, javascript被设计为单线程的语言,即使有了html5 worker,也不能直接访问dom. javascript 设计之初是为 ...
- JavaScript异步编程(2)- 先驱者:jsDeferred
JavaScript当前有众多实现异步编程的方式,最为耀眼的就是ECMAScript 6规范中的Promise对象,它来自于CommonJS小组的努力:Promise/A+规范. 研究javascri ...
- 【转】JavaScript 异步进化史
前言 JS 中最基础的异步调用方式是 callback,它将回调函数 callback 传给异步 API,由浏览器或 Node 在异步完成后,通知 JS 引擎调用 callback.对于简单的异步操作 ...
- 对Javascript异步执行的理解
简单的查看了下Javascript异步编程的代码.按照网上的说法,Javascript异步编程的核心就在于setTimeout.这个系统函数让我们将函数的执行放在了一个指定的新“线程”中.于是本来的顺 ...
- Promises与Javascript异步编程
Promises与Javascript异步编程 转载:http://www.zawaliang.com/2013/08/399.html 在如今都追求用户体验的时代,Ajax应用真的是无所不在.加上这 ...
- Javascript 异步加载详解
Javascript 异步加载详解 本文总结一下浏览器在 javascript 的加载方式. 关键词:异步加载(async loading),延迟加载(lazy loading),延迟执行(lazy ...
- javascript异步延时载入及推断是否已载入js/css文件
<html> <head> <script type="text/javascript"> /**======================= ...
- Javascript异步请求你能捕获到异常吗?
Javascript异步请求你能捕获到异常吗? 异常处理是程序发布之前必须要解决的问题,不经过异常处理的应用会让用户对产品失去信心.在异常处理中,我们一贯的做法是按照函数调用的次序,将异常从数据访问层 ...
随机推荐
- QT数据可视化框架编程实战之三维曲面图QML组件 使用高度图生成三维曲面图 补天云QT技术培训专家
QT数据可视化框架编程实战之三维曲面图 使用高度图生成三维曲面图 补天云QT技术培训专家 简介 本文将介绍如何使用QT数据可视化框架中的QT三维曲面图QML组件,通过一幅高度图的图片来生成三维曲面图. ...
- MoNA:复用跨模态预训练模型,少样本模态的福音 | ICML'24
跨模态转移旨在利用大型预训练模型来完成可能不属于预训练数据模态的任务.现有的研究在将经典微调扩展到跨模态场景方面取得了一定的成功,但仍然缺乏对模态差距对转移的影响的理解.在这项工作中,进行了一系列关于 ...
- Windows右下角时间显示具体星期
事件起因: 有时候脑子不清楚,过着过着就会忘记今天是星期几,错过一些重要事情,于是乎就想看看Windows右下角能不能显示到具体星期,果然在查了资料之后这个需求可以达成 解决办法: 控制面板 - 日期 ...
- 【VMware VCF】使用 VCF Import Tool 将现有 vSphere 环境导入为 VI 域。
VCF Import Tool 工具使用两种方式来帮助客户将现有的 vSphere 或 vSphere + vSAN 环境转变为 VMware Cloud Foundation 环境,分别是转换(Co ...
- .net6 中 Blazor PageTitle 设置无效的解决方法
直接在 razor 页面里添加 <PageTitle>xxx</PageTitle> 标签无效时的解决方法 For using the <PageTitle> ta ...
- .NET 代码混淆工具-JIEJIE.NET
前言 JIEJIE.NET是一款强大的开源.NET程序集混淆工具.它利用深度加密技术和多样化的混淆策略,有效地保护了.NET软件的版权和源代码安全,防止未经授权的访问和篡改. 项目介绍 JIEJIE. ...
- 高通USB overview
一,Dedicated Connectivity Ports (USB) 1,USB 3.1 Type-C with DisplayPort 2,Support USB3-DisplayPort Co ...
- .NET周刊【10月第1期 2024-10-06】
国内文章 基于DPAPI+RDP技术实现本地打开远程程序,并映射到本地机器桌面上 https://www.cnblogs.com/weskynet/p/18445584 该教程讲述如何使用Remote ...
- nestjs 中管道的使用-验证DTO
1. 安装管道 nest g pi role 意思是安装一个role模块的管道 2. 在controller中使用管道 管道的作用: 1. 数据的转换 2. DTO规则验证 一般使用全局配置管道 区别 ...
- 使用 Cursor 和 Devbox 快速开发并上线 Gin 项目
作为开发者,最让我们头疼的事情是什么?那必须是环境配置.版本控制以及各种部署配置等等繁琐的工作. 想象一下,如果你只需点击几下鼠标,就能拥有一个完全配置好的开发环境,支持从 Java 到 Python ...