Promise使用
程序员文章站
2022-07-03 09:33:38
...
1.常用用法
//promise主要用来解决低于回调问题
//fs.readFile是一个异步函数,如果直接调用,不使用promise,是无法返回结果
const fs = require('fs')
function getFileByPath(fpath){
//resolve是成功之后的回调函数,reject是失败之后的回调函数
var promise = new Promise(function (resolve,reject) {
fs.readFile(fpath,'utf-8',(err,data)=>{
if(err) return reject(err)
resolve(data)
})
})
return promise
}
//在调用的时候通过.then方法来制定成功和失败的回调函数
getFileByPath('./1.txt').then(function (data) {
console.log(data)
},function(err){
console.log('失败了')
})
2.连续读取3个文件
//连续读取3个文件
const fs = require('fs')
const getFileByPath = function (fpath) {
return new Promise(function (resolve, reject) {
fs.readFile(fpath, 'utf-8', (err, data) => {
if (err) return reject(err)
resolve(data)
})
})
}
//在上一个then中,返回一个新的promise实例。可以继续用下一个.then来处理
getFileByPath('1.txt').then(function (data) {
console.log(data)
return getFileByPath('2.txt')
})
.then(function(data){
console.log(data)
return getFileByPath('3.txt')
})
.then(function (data) {
console.log(data)
})
3.
//连续读取3个文件
//前面读取失败,后面继续执行,可以用.then单独执行每一个失败的回调
const fs = require('fs')
const getFileByPath = function (fpath) {
return new Promise(function (resolve, reject) {
fs.readFile(fpath, 'utf-8', (err, data) => {
if (err) return reject(err)
resolve(data)
})
})
}
//在上一个then中,返回一个新的promise实例。可以继续用下一个.then来处理
getFileByPath('11.txt').then(function (data) {
console.log(data)
}, function (err) {
console.log('读取失败')
return getFileByPath('2.txt')
})
.then(function (data) {
console.log(data)
return getFileByPath('3.txt')
})
.then(function (data) {
console.log(data)
})
4.
//连续读取3个文件
//前面promise执行失败,则立即终止所有promise的执行
const fs = require('fs')
const getFileByPath = function (fpath) {
return new Promise(function (resolve, reject) {
fs.readFile(fpath, 'utf-8', (err, data) => {
if (err) return reject(err)
resolve(data)
})
})
}
//在上一个then中,返回一个新的promise实例。可以继续用下一个.then来处理
getFileByPath('11.txt').then(function (data) {
console.log(data)
})
.then(function (data) {
console.log(data)
return getFileByPath('3.txt')
})
.then(function (data) {
console.log(data)
})
.catch(function (err) {
console.log('catch方法可以捕获错误并阻止后续的执行')
})
上一篇: Promise使用
推荐阅读
-
省点花锦鲤卡app怎么激活 省点花锦鲤卡激活后怎么使用
-
Android自定义View 使用PathMeasure简单模仿系统ProgressBar(四)
-
solidworks零件模型怎么使用剖面命令?
-
Android studio怎么使用git获取最新内容然后合并?
-
省点花锦鲤卡可以在美团上使用吗 省点花锦鲤卡app怎么在美团上用
-
Wing FTP Server FTP服务器端中文版安装使用教程
-
eclipse格式化代码快捷键无法使用怎么办?
-
android使用DataBinding来设置空状态
-
IDPhotoStudio证件照打印使用教程
-
百中搜优化软件怎么样?百中搜优化软件使用教程(附视频教程)