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);})
// }) // 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);})
标签:console,log,utf8,thenFS,JS,Promise,readFile,txt 来源: https://www.cnblogs.com/ZXSNB/p/16439586.html