promise这个东西,我都不知道见过多少回了!,非常重要,这里在回忆一遍

发现问题

const fs = require('fs')

fs.readFile('./data/1.txt', (err, data) => {
console.log(111)
fs.readFile('./data/2.txt', (err, data) => {
console.log(222)
fs.readFile('./data/3.txt', (err, data) => {
console.log(333)
})
})
}) // Promise

使用promise

/**
* Promise 在 Ecmascript 6 中体现出来就是一个对象
* Promise 是一个容器
* 一般用来封装一个异步操作
* 异步操作是一个无法预测的事情,要吗成功,要吗失败
* 容器内部有三种状态:
* pending 正在处理
* resolved 成功,已解决
* rejected 驳回,失败
*/ const fs = require('fs') // Promise 对象一经创建,立即执行
new Promise((resolve, reject) => {
fs.readFile('./data/2.txt', (err, data) => {
if (err) {
// 当 Promise 对象内部的异步操作结果失败的时候,告诉 Promise 对象容器,该异步任务失败了
// 其实就是将 Promise 内部的 Pending 状态改为 Rejected
reject(err)
}
// 当代码执行到这里,说明该 Promise 对象内部的异步操作没有错误发生,证明成功了
// 然后在这里将 Promise 内部的 Pending 状态改为 Resolved
resolve(data)
})
})
// Promise 实例对象有一个方法:then 方法
// then 需要传递两个回调处理函数
// 其中第一个回调处理函数就是 Promise 对象内部的 resolve 函数
// 第二个回调处理函数是可选的,如果传递则就是 Promise 对象内部的 reject 函数
.then((data) => {
console.log(111)
console.log(data.toString())
return new Promise((resolve, reject) => {
fs.readFile('./data/3.txt', (err, data) => {
if (err) {
// 这里没有使用 return 的原因就是 Promise 的状态只能从 Pending 变为 Resolve 或者 Rejected
// 状态一旦改变,就不会再发生变化
reject(err)
}
resolve(data)
})
})
}, (err) => {
console.log('读取文件失败了')
})
// then 方法之后可以继续链式调用 then
// 后续的每一个 then 中指定的回调处理函数都会被执行
// 后续的 then 中指定的回调处理函数可以接收上一个 then 中指定的成功的回调处理函数的返回结果
// 1. 没有返回值,默认就是 undefined
// 2. 有普通的返回值,数字、字符串、对象、数组。。。
// 3. 返回一个新的 Promise 对象
.then((data) => {
console.log(222)
console.log(data.toString())
return new Promise((resolve, reject) => {
fs.readFile('./data/1.txt', (err, data) => {
if (err) {
// 这里没有使用 return 的原因就是 Promise 的状态只能从 Pending 变为 Resolve 或者 Rejected
// 状态一旦改变,就不会再发生变化
reject(err)
}
resolve(data)
})
})
})
.then((data) => {
console.log(333)
// 二进制数据调用 toString() 方法可以转换为普通的字符,默认就是 utf8 编码
console.log(data.toString())
})

封装promise

const fs = require('fs')

readFile('./data/1.txt', 'utf8')
.then(data => {
console.log(data)
return readFile('./data/2.txt', 'utf8')
})
.then(data => {
console.log(data)
return readFile('./data/3.txt', 'utf8')
})
.then(data => {
console.log(data)
}) function readFile(...args) {
return new Promise((resolve, reject) => {
fs.readFile(...args, (err, data) => {
if (err) {
reject(err)
}
resolve(data)
})
})
}

html页面中promise

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>XMLHttpRequest - Promise</title>
</head>
<body>
<div>
姓名:
年龄:
</div>
<script> function xhr(options) {
return new Promise(function (resolve, reject) {
var xhr = new XMLHttpRequest()
xhr.open(options.type || 'get', options.url)
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
resolve(xhr.responseText)
} else {
reject()
}
}
xhr.send()
})
} xhr({
url: '',
type: '',
data: ''
})
.then(data => {
return xhr({ })
})
.then(data => {
// 做渲染处理
}) $.ajax({ }).then(data => {
return $.ajax({ })
})
.then(data => { })
</script>
</body>
</html>

处理错误--最后

这种事把错误放在最后处理

当然,也可以在中间处理错误

不过一般都在最后处理

const fs = require('fs')

readFile('./data/4.txt', 'utf8')
.then(data => {
console.log(data)
return readFile('./data/2.txt', 'utf8')
})
.then(data => {
console.log(data)
JSON.parse('{dsadsa')
return readFile('./data/3.txt', 'utf8')
})
.then(data => {
console.log(data)
})
// 在使用 Promise 做异步流程控制的时候,关于异常的处理可以通过在最后一个 then 之后设置一个 catch
// 然后指定一个失败处理函数
// 该函数可以捕获前面所有的 Promise 对象本身以及 then 内部的任务错误
// 当前面任何一个发生异常,直接进入 catch,后续所有的 Promise 包括 then 不再执行
.catch(err => {
console.log(err)
}) function readFile(...args) {
return new Promise((resolve, reject) => {
fs.readFile(...args, (err, data) => {
if (err) {
reject(err)
}
resolve(data)
})
})
}

promise-resolve不支持多参数

最新文章

  1. Eclispe远程调试tomcat设置
  2. socket入门基础
  3. wsimport命令讲解
  4. asp.net导出dbf报错“未在本地计算机上注册“VFPOLEDB”提供程序。”
  5. maven web启动报错java.lang.ClassNotFoundException: org.springframework.web.util.Log4jConfigListener
  6. [CCF] ISBN号码检测
  7. QQ JS省市区三级联动
  8. 玩转Web之Json(三)-----easy ui怎么把前台显示的dataGird中的所有数据序列化为json,返回到后台并解析
  9. php键值相同的项数值相加
  10. Elcipse安装gradle插件
  11. ElasticSearch 启动时加载 Analyzer 源码分析
  12. SAS 对数据的拼接与串接
  13. 2、买卖股票的最佳时机 II
  14. HDU 1247 Hat’s Words(字典树)
  15. Python3入门 Python3+Selenium做UI页面测试的学习
  16. [P2051 [AHOI2009]中国象棋] DP
  17. 33. 完全卸载oracle11g步骤
  18. poj 3630 Phone List 贪心
  19. webpack 提升90%的构建速度 HardSourceWebpackPlugin
  20. linux下怎么查找文件

热门文章

  1. Codeforces_801
  2. Python 进行目标检测
  3. LeetCode#26 | Remove Duplicates from Sorted Array 删除有序数组中的重复元素
  4. MySQL关系型数据库基础操作
  5. Hapi+MySql项目实战配置插件-加载文件渲染母版(三)
  6. Apache 安装 静态编译 动态编译
  7. vi/vim编辑器操作梳理
  8. [ERROR]pyodbc.ProgrammingError: (&#39;42000&#39;, &#39;[42000] [Microsoft][ODBC Driver 17 for SQL Server][SQL Server]SQL Server 阻止了对组件“xp_cmdshell”的 过程“sys.xp_cmdshell”的访问
  9. 珠峰-node
  10. Android Studio无法下载sdk的问题