一、Promise的前言

解决回调地狱

//以往回调方式
函数1(function(){
//代码执行...(ajax1) 函数2(function(){
//代码执行...(ajax2) 函数3(function(data3){
//代码执行...(ajax3)
});
...
});
}); //Promise回调方式:链式调用,可构建多个回调函数。
//例如请求一个ajax之后,需要这个拿到这个ajax的数据去请求下一个ajax
promise().then().then()...catch()

当页面逻辑复杂起来的时候,管理起来特别不容易。

为解决这种问题,CommonJS提出Promise概念.

  • 从字意去理解:Promise表示一种承诺,它拥有由浏览器引擎提供的两个函数:resolve和reject.通过具体情况调用相应的函数,然后再通过then写上对应的回调函数。
  • 从构建代码理解:
//首先要创建Promise实例
let promise = new Promise( (resolve, reject) => {
//执行相应代码并根据情况调用resolve或reject
...
}) //在promise的then方法中执行回调
promise.then(function(){
//第一个参数是返回resolve时,回调执行的函数
},function(){
//第二个是回调返回reject时,回调执行的函数
}
}

解释一下上面几个概念:

  • Promise: Promise有三个状态:pending(等待)、resolve(完成)、 reject(拒绝)

    两种状态改变方式:pending => resolve, pending => reject

    在构建Promise实例调用resolve或reject就是状态改变的时候。当状态改变的时候,其方法then就会执行对应状态的回调函数。

  • resolve: then方法的第一个参数,通常作为事件成功的回调函数

  • reject: then方法的第二个参数,通常作为事件失败的回调函数,也可以作为catch的参数出现

二、Promise入门小例子

定时器调用

  1. 最简单的例子
const promise = new Promise(function(resolve, reject){
setTimeout(resolve,1000);//1s后状态变更为resolve,调用then方法的第一个参数
}) promise.then(function(){
console.log('resolve:成功回调函数')
},function(){
console.log('reject:失败回调函数')
})

  1. 也可以写成回调函数的方式,并把reject状态的回调函数放到catch里
const promise = new Promise((resolve, reject) => {
setTimeout(reject,1000);
}) promise.then( () => {
console.log('resolve:成功回调函数')
}).catch(() => {
console.log('reject:失败回调函数')
})
  1. 请求事件通常会附带数据给回调函数。要传递参数,只需要附带在函数后面即可

    注意!传多个数据需要通过数组传递
const promise = new Promise((resolve, reject) => {
setTimeout(reject,1000,'我是value值');
}) promise.then((value) => {
console.log('resolve:' + value)
}).catch((value) => {
console.log('reject:'+ value)
})

传多个参数➡

//第一种,可以看到单个传值是无效的
const promise = new Promise((resolve, reject) => {
setTimeout(resolve,1000,'参数1','参数2');
}) promise.then((value1,value2) => {
console.log('value1:' + value1) //value1:参数1
console.log('value2:' + value2) //value2:undefined
}).catch((value) => {
console.log(value)
})
//第二种:数组传值
const promise = new Promise((resolve, reject) => {
setTimeout(resolve,1000,['参数1','参数2']);
})
promise.then((value1) => {
console.log('value1:' + value1) //value1:参数1,参数2
}).catch((value) => {
console.log(value)
})

以上就是我对Promise的理解啦!是一些Promise入门的简单知识点.

想深入了解的话可以看看阮一峰老师的《ES6入门》:

http://es6.ruanyifeng.com/#docs/promise

ES6中Promise的入门(结合例子)的更多相关文章

  1. es6中promise实现ajax的例子

    function getData(url){ var pro = new Promise(function(resolve,reject){ var xhr = null; try{ xhr = ne ...

  2. ES6中promise的使用方法

    先看看ES5中异步编程的使用. let ajax = function (callBlack) { setTimeout(function () { callBlack && call ...

  3. 对于ES6中Promise的个人见解

    1.js中常见的异步 JavaScript可以响应用户的一些异步交互,比如单击鼠标和按键盘等操作. let button = document.getElementById("btn&quo ...

  4. ES6中Promise对象个人理解

    Promise是ES6原生提供的一个用来传递异步消息的对象.它减少了传统ajax金字塔回调,可以将异步操作以同步操作的流程表达出来使得代码维护和可读性方面好很多. Promise的状态: 既然是用来传 ...

  5. ES6中promise总结

    一.什么是ES6的Promise 讲太多也没有.直接在打印出来就好,console.dir(Promise) Promise 是一个构造函数,自身有all, reject, resolve 这几个眼熟 ...

  6. ES6 中 Promise

    在说Promise之前我们先简单说一下什么是同步异步? 同步(Sync):所谓同步,就是发出一个功能调用时,在没有得到结果之前,该调用就不返回或继续执行后续操作. 异步(Async):异步与同步相对, ...

  7. ES6 中 Promise 详解

    Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise 是一个对象,从它可以获取异步操作的消息.Promise 提供统一的 API ...

  8. ES6中Promise详解

    Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise 是一个对象,从它可以获取异步操作的消息. Promise 提供统一的 AP ...

  9. 阿里前端测试题--关于ES6中Promise函数的理解与应用

    今天做了阿里前端的笔试题目,原题目是这样的 //实现mergePromise函数,把传进去的数组顺序先后执行,//并且把返回的数据先后放到数组data中 const timeout = ms => ...

随机推荐

  1. Spring Batch 远程分区和远程分块的区别

    Partitioning is a master/slave step configuration that allows for partitions of data to be processed ...

  2. JustOj 1414: 潘神的排序

    题目描述 老潘,袁少,小艾都是江理的大个子,他们想按身高排队,现在给你他们的身高,请你算出队伍中站在第二的有多高. 输入 输入三个整数,分别表示三个人的身高.(单位:纳米) 输出 输出身高排第二的身高 ...

  3. kali linux中文输入法

    kali linux中文输入法 已经使用kali linux有一段时间来,越用越喜欢,真的奥! 最近又有宝宝问我kali linux的中文输入法,鉴于当初在坑里蹲了很长时间,还是记录一下吧! The ...

  4. Java连接数据库 #04# Apache Commons DbUtils

    索引 通过一个简单的调用看整体结构 Examples 修改JAVA连接数据库#03#中的代码 DbUtils并非是什么ORM框架,只是对原始的JDBC进行了一些封装,以便我们少写一些重复代码.就“用” ...

  5. 标准库 string

    1.func Fields(s string) []string,这个函数的作用是按照1:n个空格来分割字符串最后返回的是[]string的切片 package main import ( " ...

  6. c语言cgi笔记

    直接输出接收的数据 #include <stdio.h>#include <stdlib.h>main(){int i,n;printf ("Content-type ...

  7. Bitbucket备份恢复

    我们需要备份什么? home directory:contains  repository data, log files, plugins, and so on. database:contains ...

  8. JavaScript中数组中的方法:push()、pop()、shift()、unshift()、slice()、splice()、reverse()、join()、split()、concat()、indexOf()、forEach()、map()、

      1.创建数组的几种方法 //a).通过new来创建数组,new可以省略 var arr=new Array(); var arr=Array(); //b). .通过new来创建数组,并且赋值 v ...

  9. 一、变量.二、过滤器(filter).三、标签(tag).四、条件分支tag.五、迭代器tag.六、自定义过滤器与标签.七、全系统过滤器(了解)

    一.变量 ''' 1.视图函数可以通过两种方式将变量传递给模板页面 -- render(request, 'test_page.html', {'变量key1': '变量值1', ..., '变量ke ...

  10. PyCharm笔记之首次安装和激活

    转载:http://www.cnblogs.com/Ivyli4258/p/7440147.html PyCharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其 ...