微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JS Promise

//1. promise是一个构造函数: // 创建一个promise实例: // const p=new Promise();(代表一个异步操作) //2. Promise.prototype上包含一个.then()方法,因此每一次new Promise()构造函数得到的实例对象都可以通过原型链的方式访问到.then()方法: // 例如 p.then(); // 3. .then()方法用来预先指定成功和失败的回调函数 // p.then(成功的回调函数(必选),失败的回调函数) // 4.基于then-fs读取文件内容:安装 then-fs包,then-fs提供一个readFile()方法,可异步读取文件内容(不保证读取顺序),他返回值是promise实例对象; import thenFS from 'then-fs' // thenFS.readFile('','utf8').then((res)=>{
// }) // promise支持链式调用(以此来按顺序读取文件): // thenFS.readFile('./file/1.txt','utf8').then((r1)=>{ //     console.log(r1); //     return thenFS.readFile('./file/2.txt','utf8'); // }).then((r2)=>{ //     console.log(r2); //     thenFS.readFile('file/3.txt','utf8'); // }).then((r3)=>{ //     console.log(r3); // }) // 5. 通过.catch()捕获其之前错误:     // thenFS.readFile('./file/1.txt','utf8').then((r1)=>{     //     console.log(r1);     //     return thenFS.readFile('./file/2.txt','utf8');     // })     // .catch(err=>{     //     console.log(err.message);     // })     // .then((r2)=>{     //     console.log(r2);     //     thenFS.readFile('file/3.txt','utf8');     // }).then((r3)=>{     //     console.log(r3);     // }) // 6.promise.all方法()发起并行的异步操作,等所有异步操作全结束后才会执行.then()操作 // const promiseArr=[ //     thenFS.readFile('./file/1.txt','utf8'), //     thenFS.readFile('./file/2.txt','utf8'), //     thenFS.readFile('./file/3.txt','utf8'), // ] // Promise.all(promiseArr).then(result=>{ //     console.log(result); // }) // ['111','222','333'] // 7.promise.race()方法只要任何一个异步操作完成,就立即执行下一个.then()操作 // Promise.race(promiseArr).then(result=>{ //     console.log(result); // })


// 8.自定义getFile方法: import fs from 'fs'
function getFile(fpath){     return new Promise(function(resolve,reject){ //function()里是一个具体的异步操作         fs.readFile(fpath,'utf8',(err,dataStr)=>{             if(err) return reject(err);             resolve(dataStr);         })     }) }
getFile('./file/1.txt').then((r1)=>{console.log(r1);},(err)=>{console.log(err,message);})

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐