加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
练习promise.html 3.49 KB
一键复制 编辑 原始数据 按行查看 历史
淘豆 提交于 2022-02-11 22:16 . 初始化项目
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>promise</title>
</head>
<body>
<button onclick="testPromise()">测试链式调用</button>
<script>
const a = Math.random()
const b = Math.random()
new Promise(function(resolve, reject) {
if (a > b) {
//此时认为成功
resolve("我成功了")
} else {
//否则失败
reject("我失败了")
}
})
.then((result) => {
//这里获取的是成功的结果
console.log(result)
})
.catch((error) => {
//这里获取的是失败的结构
console.log(error);
})
</script>
<script>
function testAxios() {
axios({
url: "",
})
.then((result) => {
//发起第二次请求
return axios({
url: "2",
params: result
})
})
.then((result) => {
//此时的result结果是 上次的promise执行的结果
return axios({
url: "3",
params: result,
})
})
.then((result) => {
//此时的result结果是 上次的promise执行的结果
return axios({
url: "4",
params: result,
})
})
.then((result) => {
return axios({
url: "5",
params: result,
})
})
}
//promise 最大的作用是 将回调地狱的写法变成链式调用
</script>
<script>
function testPromise() {
new Promise(function(resolve, reject) {
//想要3秒钟之后成功执行 得到一个15000的结果
setInterval(() => {
resolve(15000) //起薪
},
3000)
})
.then((result) => {
// alert(result)
// //返回的是一个值或者是一个promise对象
// return new Promise()
return result + 1000
})
.then((result) => {
return result + 1000
})
.then((result) => {
return result + 1000
})
.then((result) => {
return new Promise(function(resolve, reject) {
resolve(result + 2000)
})
})
.then((result) => {
//只有等到上一个结果执行完毕
//在这个位置获取上一个的结果
alert(result)
})
.catch((error) => {
alert(error)
})
}
</script>
</body>
</html>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化