es6中then的写法是什么
时间:2022-05-06 [网络编程]作者:fabuyuan 浏览:5 次
在es6中,then的写法是“then(为promise实例添加状态改变成功的回调函数,失败的回调函数)”;该方法用于为promise实例添加状态改变时的回调函数,返回的结果是一个新的promise实例,并且该方法可以采用链式操作。
本教程操作环境:windows10系统、ECMAScript 6.0版、Dell G3电脑。
es6中then的写法是什么
写法:
then(参数1,参数2)
作用:为promise实例添加状态改变时的回调函数
参数1是成功的回调函数,
参数2是失败的回调函数
返回值:then()方法返回的是一个新的promise实例,then()方法可以采用链式操作.
扩展知识:
Promise
1.概念:Promise是异步编程的一种解决方案.
2.异步:之前实现异步操作的方式:①回调函数②事件触发
3.作用:解决异步操作问题,区别于上述的两种方法.
4.特点: ①:对象的状态不受外界的影响,promise对象代表一个异步操作,有三种状态:Pending(进行中).fulfilled(已成 功).rejected(已失败).只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态.
②:对象的状态,一旦改变,就不会再变,任何时候都可以得到这个结果.(Promise对象的状态改变,只有两种可能:从penging变为fulfilled和pending变为rejected).
5:基本用法
(1)通过new promise对象可以创建promise实例
const promise=new Promise(function(resolve,reject){})
(2)参数说明:promise对象接收一个函数做参数,这个函数的参数分别是resolve和reject它们是两个函数,由Javascript引擎提供
(3)resolve函数的作用:在异步操作成功时调用,并将异步操作的结果,作为参数传递出去.
(4)reject函数的作用:在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去.
说明:promise实例生成以后可以用then方法分别指定成功和失败的回调函数
.then()是promise实例的一个方法,表示要执行的下一步操作.
例如:
function ajax(){ console.log("hello"); return new Promise(function(resolve,reject){ setTimeout(function(){ resolve(); },1000) }) ajax.then(function(){ console.log("world"); }) }
6.Promise实例的方法
(1)then(参数1,参数2)
作用:为promise实例添加状态改变时的回调函数
参数1是成功的回调函数,参数2是失败的回调函数
返回值:then()方法返回的是一个新的promise实例,then()方法可以采用链式操作.
(2)catch()
作用:指定发生错误时的回调函数,作用等同于then方法的第二个参数
例如:
let ajax=function(num){ return new Promise((resolve,reject){ if(num>5){ resolve(num); }else{ throw new Error("出错了"); } }) } ajax(2).then(function(num){ console.log(num); }).catch(function(error){ console.log(error); })
7.Promise的高级方法
(1)promise.all()
作用:将多个promise实例,包装成一个新的promise实例,简单的来说就是多个异步操作都成功则才执行成功的回调,否则执行失败的回调.
参数说明:接收一个数组作为参数,数组的每一项都是promise实例
(2)promise.race()
作用:将多个promise实例,包装成一个新的promise实例,只要有一个实例率先改变状态,promise的状态就跟着改变.
参数说明:接收一个数组作为参数,数组的每一项都是promise实例
8.Promise风格的AjAx
function promiseAjax(json){ let url=json.url; let type=json.type||"get"; let data=json.data||{}; let str=""; for(let k in data){ str+=k+"="+data[k]+"&"; } return new Promise((resolve,reject)=>{ let ajax=new XMLHttpRequest(); if(type.toLowerCase()==="get"){ ajax.open("get",`${url}?${str}time=${Date.now()}`,true); ajax.send(); }else if(type.toLowerCase()==="post"){ ajax.open("post",url,true); ajax.setRequestHeader("content-type","application/x-www-form-urlencoded"); ajax.send(str.substring(0,str.laseIndexOf("&"))); } ajax.onreadystatechange=function(){ if(ajax.readyState===4){ if(ajax.status>=200&&ajax.status<300){ resolve(JSON.parse(ajax.responseText)); }else{ let error=new Error(); error.status=ajax.status; reject(error); } } } }) }
【相关推荐:javascript视频教程、web前端】
以上就是es6中then的写法是什么的详细内容,更多请关注站长家园其它相关文章!
本文标签: ES6
转载请注明来源:es6中then的写法是什么
本文永久链接地址:https://www.adminjie.com/post/12033.html
免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!
版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。
更多精彩内容
- VUE中V-IF条件判断改变元素的样式操作
- Discuz如何解决安装时报错run_sql_error
- 低版本VS项目在VS2019无法正常编译的问题
- PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
- Oracle数据库的实例/表空间/用户/表之间关系简单讲解
- RSA2是啥?PHP-RSA2签名验证怎么实现?
- 华为dubal20是什么型号
- html5的标题标记一共有几个等级
- ana an00华为是什么型号
- 电脑显示信号线无连接是什么意思
- app是什么应用程序的简称
- html5中onclick是什么意思
- vivov1818a是什么手机型号
- 超链接的作用是什么
- 小程序大小超限除了分包还能怎么做?如何避免和解决大小限制?

- 最新文章
-
-
linux中什么是静态路由
在linux中,静态路由是路由项由手动设置的一种路由方式;即使网络状态已经改变或重新被组态,静态路由也是固定不变的,静态路由由网络管理员逐项加入路由表,可用“r...
-
php数组相加会合并重复值么
php数组相加不会合并重复值。php中可使用“+”运算符将一个或多个数组相加起来,会合并这些数组返回一个新数组,语法“数组1+数组2+..”,后面数组的元素会追...
-
php怎么去掉数组前一个元素
方法:1、用“array_values($arr)”将数组转为索引数组;2、用“array_search(值,数组)”从索引数组中搜索值,并返回对应索引;2、用...
-
浅析nodejs项目中的package.json的常见配置属性
本篇文章带大家了解一下node项目中的package.json配置文件,聊聊package.json中一些常见配置属性、环境相关属性、依赖相关属性和三方属性,希...
-
聊聊如何利用uniapp开发一个贪吃蛇小游戏!
如何利用uniapp开发一个贪吃蛇小游戏?下面本篇文章就手把手带大家在uniapp中实现贪吃蛇小游戏,希望对大家有所帮助!第一次玩贪吃蛇还隐约记得是?️后父亲给...
-
- 热门文章
-
-
VUE中V-IF条件判断改变元素的样式操作
这篇文章主要介绍了VUE中V-IF条件判断改变元素的样式操作,具有很好的参考价值,希望对大家有所帮助。一起跟随想过来看看吧...
-
Discuz如何解决安装时报错run_sql_error
问题环境VMware虚拟机Centos7.3PHP7.0MySQL8.0NGINX1.14Discuz3.4问题还原本地环境为PHP5.6+MySQL5.6在安...
-
低版本VS项目在VS2019无法正常编译的问题
低版本VS项目在VS2019无法正常编译的问题这里指的编译并不准确,只是为了方便说明。后有(未安装),201?...
-
PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
实现原理使用redis链表来做,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行,推荐使用。实现步骤第一步,先将商品库存入队列/**.trigge...
-
Oracle数据库的实例/表空间/用户/表之间关系简单讲解
完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例。Oracle是一种数据库管理系统,是一种关系型的数据库管理系统。我们用这些高级权限账号...
-