Home  >  Article  >  Web Front-end  >  Detailed introduction to the knowledge points about promises in js

Detailed introduction to the knowledge points about promises in js

亚连
亚连Original
2018-06-08 10:57:491417browse

Now I will share with you a brief discussion on the use of js promise. It has a very good reference value and you will understand it after reading this article. I hope to be helpful.

1. Background

Everyone knows that nodejs is very fast. Why is it so fast? The reason is that node uses asynchronous callbacks to process Events that need to be waited for allow the code to continue executing without waiting somewhere. But there is also a disadvantage. When we have many callbacks, for example, after executing this callback, we need to execute the next callback, and then execute the next callback. This will cause layers of nesting and unclear code, which is very difficult. It is easy to enter the "callback jail", which can easily lead to the following example:

async(1, function(value){
 async(value, function(value){
 async(value, function(value){
  async(value, function(value){
  async(value, function(value){
   async(value, final);
  });
  });
 });
 });
});

This way of writing will make people collapse, so is there any way to solve this problem, or is there any other way of writing? The answer is yes. The new promise object of es6 and the async await of es7 can solve this problem. Of course, the promise object will be introduced here first, and the async await of es7 will be shared in the following articles. The Promise object will be introduced below.

2. Introduction

Promise is an object that is used to handle asynchronous operations. It allows us to write asynchronous calls. It is more elegant to write, more beautiful and easier to read. As the name suggests, it means promise, which means that after using Promise, he will definitely give us a reply, no matter whether it succeeds or fails, he will give us a reply, so we don't have to worry about him running away, haha. Therefore, Promise has three states: pending (in progress), resolved (completed), and rejected (failed). Only structures returned asynchronously can change their state. Therefore, there are generally only two promise processes: pending->resolved or pending->rejected.

The promise object also has a more commonly used then method, which is used to execute the callback function. The then method accepts two parameters. The first is a successful resolved callback, the other is a failed rejected callback, and the second Optional callback parameters for failure. And the then method can also return a promise object, so that it can be called in a chain. Next, the code:

var Pro = function (time) {
   //返回一个Promise对象
   return new Promise(function (resolve, reject) {
    console.log('123');
    //模拟接口调用
    setTimeout(function () {
     //这里告诉Promise 成功了,然后去执行then方法的第一个函数
     resolve('成功返回');
    }, time);
   })
  };
  (function(){
   console.log('start');
   Pro(3000)
   .then(function(data){
    console.log(data);
    return Pro(5000);})
   .then(function(data){
    console.log(data);
    console.log('end');
   })
  })();

In the above code, a Pro variable is defined, and then an anonymous function is assigned to it. The function returns a Promise object, and then receives a function in the object, and uses the resolve and reject methods respectively. When the parameters are passed in, setTimeOut is used to simulate an asynchronous request. When the resolve method is executed, a function of the then method will be called. The results are as follows:

##3. Promise’s api

1. Promise.resolve()

2, Promise.reject()
3, Promise.prototype.then()
4, Promise.prototype.catch()
5, Promise.all() // All are completed, Equivalent to and
6. Promise.race() // Just complete one, equivalent to or

1. The function of Promise.resolve() is to convert the existing object into a Promise object resolvedl;Promise. resolve('test')==new Promise(resolve=>resolve('test'))

2. Promise.reject() also returns a Promise object with a status of rejected;

3. The then method has been introduced above and will not be introduced here.

4. catch(): callback function when an error occurs.

5. Promise.all() is suitable for executing then() successfully after all results are completed. For example:

let p1 =new Promise(function(resolve,reject){
   resolve(1);
  });
  let p2 = new Promise(function(resolve,reject){
   resolve(2);
  });
  let p3 = new Promise(function(resolve,reject){
   resolve(3);
  });
  Promise.all([p1, p2, p3]).then(function (results) {
   console.log('success:'+results);
  }).catch(function(r){
   console.log("error");
   console.log(r);
  });

Final output:

6. The function of Promise.race() is to execute multiple instances at the same time, as long as one instance changes State, the Promise is changed to the state changed by that instance;

4. Example

var Pro = function () {
   //返回一个Promise对象
   return new Promise(function (resolve, reject) {
    //模拟接口调用
    setTimeout(function () {
     resolve(true);
    }, 1000);
   })
  };
  var Pro2 = function () {
   //返回一个Promise对象
   return new Promise(function (resolve, reject) {
    //模拟接口调用
    setTimeout(function () {
     resolve('Pro2成功执行');
    }, 1000);
   })
  };
  
  Pro().then(function(data){
   var val = data;
   console.log(val)
   if (val) {
    console.log(1111)
    return Pro2()
   }
   
  }).then(function(data1){
   console.log(data1)
  })

Output:

In this way, you can use the then method to implement chain calls.

The above is what I compiled for everyone. I hope it will be helpful to everyone in the future.

Related articles:

JavaScript Mediator Pattern (detailed tutorial)

How to use the Dom element in jQuery?

How to implement event-responsive progress bar component in Vue

The above is the detailed content of Detailed introduction to the knowledge points about promises in js. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn