No.52 ES6---Promise对象

news/2025/3/11 11:18:38/文章来源:https://www.cnblogs.com/bltstop/p/18764645

一、Promise对象

1.1基本概念

  • Promise 是异步编程的一种解决方案,比传统的解决方案--回调函数和事件----更合理和更强大。
  • 它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Promise 对象。

 

  • 所谓 promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果。
  • 从语法上说,Promise 是一个对象,从它可以获取异步操作的消息。
  • Promise 提供统一的 API,各种异步操作都可以用同样的方法进行处理。

 

  • 有了 Promise 对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。
  • 此外Promise 对象提供统一的接口,使得控制异步操作更加容易。

1.2 基本用法

  • ES6 规定,Promise 对象是一个构造函数,用来生成 Promise 实例。

  • Promise 构造函数接受一个函数作为参数,该函数的两个参数分别是 resolve 和 reject 。它们是两个函数,由JavaScript 引擎提供,不用自己部署。
  • Promise 实例生成以后,可以用 then 方法分别指定 resolved 状态和 rejected 状态的回调函数。

 

示例:加载图片资源的例子

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>div{width: 300px;height: 200px;}</style>
</head><body><div id="box">等待图片加载 loading...</div><script>var box = document.getElementById("box");function loadImageZ(url){   //url:图片的地址const promise = new Promise(function(resolve,reject){//异步处理:消耗时间的代码const image = new Image();   //创建Image对象image.src = url;image.onload = function(){resolve(image)}image.onerror = function(){reject(new Error('Could not load image at' + url))}})return promise;}const promise = loadImageZ("D:/壁纸/111.jpg");promise.then(function(data){//成功box.appendChild(data);},function(error){//失败box.innerHTML="图片加载失败";console.log(error);})</script>
</body></html>

  

 

二、Promise对象---Ajax实操

  • Promise封装Ajax,让网络请求的异步操作变得更简单。

 



 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/897162.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

类型转换+变量+常量+作用域

类型转换+变量+常量+作用域强制转换 (类型)变量名 高-->低 自动转化 低-->高 注意点不能对布尔值进行转换 不能把对象类型转换为不相干的类型 在把高容量转换到低容量的时候,强制转换 转换的时候可能存在内存溢出,或者精度问题变量变量作用域常量

ITSM流程落地经验之变更管理

本文来自腾讯蓝鲸智云社区用户: CanWay大多数组织中都实施了变更管理,但是效果参差不齐,尤其在变更管理的核心环节,部分组织因缺乏有效的把控,使得变更管理的效果不尽人意,甚至可能面临失控的风险。为此,我们有必要深入探讨并详细分析变更管理中的关键活动,并通过实例加…

国货国用信创在教育领域的应用

信创,即信息技术应用创新产业,旨在实现信息技术领域的自主可控,减少对国外技术的依赖,保障国家信息安全。在教育领域,国货国用信创的应用正逐渐改变着传统的教育模式,为教育的现代化发展注入新的活力。随着科技的飞速发展,教育领域也面临着数字化转型的迫切需求。信创产…

信创概念十大龙头股的风险与机遇深度剖析

信创,即信息技术应用创新产业,旨在实现信息技术领域的自主可控,减少对国外技术的依赖,保障国家信息安全。近年来,随着国家政策的大力支持和科技发展的需求,信创概念逐渐兴起,相关企业迎来了前所未有的发展机遇。在信创概念板块中,有十大龙头股备受关注,它们在行业中具…

易基因:中农大曾祥芳团队WGBS+ChIP-seq揭示蛋氨酸在母胎免疫耐受和子宫内膜容受中的表观调控机制|Cell Rep

大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。 母胎免疫耐受是指母体免疫系统对胎儿抗原的耐受,避免对胎儿产生免疫排斥反应。子宫内膜容受性是指子宫内膜接受胚胎着床的能力。子宫内膜容受性和母胎免疫耐受是成功妊娠的两个关键过程。然而,营养所涉及的分…

【文章】更新说明

重要 以后文章优先发布于公众号:瓜穷网络安全团队,请大家关注公众号。本文来自博客园,作者:aoaoaoao,转载请注明原文链接:https://www.cnblogs.com/websecyw/p/18764593

牛客题解 | 迷宫寻路

牛客题库题解题目 题目链接 题解 难度:偏难 知识点:BFS 状态压缩 队列 思路: 如果不存在钥匙和锁的情况:(理解BFS过程) (将例子中的小写字母看为1,大写字母看为0)构成数组G[5][5]起始位置G[0][1],因此得到b[0][1]=0【注】辅助数组b[i][j]用来记录从起始位置到坐标(i…

信创国产替代必看:5款好用的项目管理软件对比

随着信息技术的快速发展,国产替代成为了当前的一个重要趋势。在项目管理系统领域,国产软件也在不断崛起,与国外知名的项目管理工具如 Jira、Asana 等展开竞争。本文将对 5 款优秀的项目管理系统的功能进行对比,帮助您更好地了解它们的特点和优势。 国产项目管理系统的发展与…

Typora安装激活(保姆级教程)

提示:该教程以Typora-1.8.10版本进行安装激活,高版本可能会出现激活失败的情况,所以安装版本尽量是1.8.10及以下版本。目录一、官网地址二、激活工具三、安装Typora四、激活Typora 一、官网地址 官网地址:https://typora.io/ 中文官网:https://typoraio.cn/ 官网下载地址:…

milvus升级(2.4.6-2.4.21)

环境:Os:Centos 7原版本:v2.4.6目标版本:v2.4.21 说明: a.提前做好备份b.升级后需要把新版本的配置文件外挂出来,不能使用原有版本的,因为每个版本的配置文件参数都有可能不一样.1.镜像准备[root@localhost milvus]# docker pull registry.cn-shenzhen.aliyuncs.com/hxlk8s/mi…

牛客题解 | 缺失的括号

牛客题库题解题目 题目链接 题解 难度:中等难度 知识点:数学逻辑 思路: 依次判断: 1.若是s[i]为“(”是,是得left++。 当s[i]为“)”时:如果left>0,说明该“)”可以和之前的“(”抵消,因此left--。若此时left=0,说明给“)”无法抵消因此right++。 2.最终left保留…

No.51 ES6---Set数据结构

一、Set数据结构 1.1 基本用法ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。 set 本身是一个构造函数,用来生成 Set 数据结构。<script>var s = new Set();var arr = [103,91,47,43,32,54,78];arr.forEach(x => s.add(x));cons…