promise学习笔记

  • 回调地狱
    • 多层回调函数的相互嵌套,就形成了回调地狱
    •  回调地狱的缺点:

      • 代码耦合性太强,牵一发而动全身,难以维护
      • 大量冗余的代码相互嵌套,代码的可读性变差
  • 如何解决回调地狱的问题
    • 为了解决回调地狱的问题,ES6中新增了Promise的概念
      • Promise的基本概念
        1. Promise是一个构造函数
          • 我们可以创建Promise的实例  const p = new Promise()
          • new 出来的Promise实例对象,代表一个异步操作
        2. Promise.prototype上包含一个.then()方法
          • 每一次new Promise()构造函数得到的实例对象,都可以通过原型链的方式访问到.then()方法,例如p.then()

                                       3.  .then()方法用来预先指定成功和失败的回调函数

                                              p.then(成功的回调函数,失败的回调函数)

                                              p.then(result =>{}, errror =>{})

                                              调用.then()方法时,成功的回调函数是必选的,失败的回调函数是可选的

                                         4.通过.catch捕获错误

   注意:thenFs 为  导入的包then-fs进行读取文件的内容 安装指令: npm install then-fs

   导入代码:

     

 

 

 

                                    

 

 如果不希望前面的错误导致后续的.then无法执行,则可以将.catch的调用提前

 

 

 

Promise.all()方法

Promise.all()方法会发起并行的Promise异步操作,等所有的异步操作全部结束后才会执行下一步的.then操作(等待机制)。

注意:数组中Promise实例的顺序,就是最终结果的顺序!!!

 

 

 

Promise.race()方法

Promise.race()方法会发起并行的Promise异步操作,只要任何一个异步操作完成,就立即执行下一步的.then操作(赛跑机制)

 

 

 

 

自定义基于Promise封装读文件的方法

方法的封装要求:

  1. 方法的名称定义为getFile
  2. 方法接收一个形参fpath,表示要读取的文件路径
  3. 方法的返回值为Promise实例对象
/* getFile方法的基本定义 */
//方法的名称定义为getFile
//方法接收一个形参fpath,表示要读取的文件路径
function getFile(fpath) {

    //方法的返回值为Promise实例对象
    return new Promise() // 注意:new Promise()只是创建了一个形式上的异步操作
}

 

创建具体的异步操作
/* 如果想要创建具体的异步操作,
则需要再new Promise()构造函数期间,传递一个function函数,
将具体的异步操作定义到function函数内部 */
//方法的名称定义为getFile
//方法接收一个形参fpath,表示要读取的文件路径
import fs from 'fs'
function getFile(fpath) {
    //方法的返回值为Promise实例对象
    return new Promise(function(){
        return fs.readFile(fpath, 'utf-8',(err,dataSrc)=> {

        })
    }) 
}

 如何获取上述代码块中成功失败的信息呢?

获取.then的两个实参

通过.then指定的成功失败的回调函数,可以在function的形参中进行接收

 

 

 

 

import fs from 'fs'
function getFile(fpath) {
    //方法的返回值为Promise实例对象
    return new Promise(function(resolve, reject){
        return fs.readFile(fpath, 'utf-8',(err,dataSrc)=> {
            if(err){
                return reject(err); // 传过来的失败回调函数
            }
            resolve(dataSrc) // 传过来的成功回调函数
        })
    }) 
}
getFile('./text/1.txt').then(resolve => {
    console.log(resolve,'success');
},reject => {
    console.log(reject,'danger');
})

  

posted @ 2022-05-24 16:14  perfect*  阅读(22)  评论(0编辑  收藏  举报
$(function() { $('#cnblogs_post_body img').each(function() { let imgSrc = $(this).attr('src'); let year = parseInt(imgSrc.substr(imgSrc.indexOf('g')+1,4)); if(year >= 2022){ imgSrc += `?watermark/2/text/amlndWl5YW4=/font/5a6L5L2T/fontsize/15/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast`; $(this).attr('src', imgSrc) } }) })