【Promise】第一部分 介绍Promise

导读:本篇文章讲解 【Promise】第一部分 介绍Promise,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

【Promise】第一部分 介绍Promise



1. 介绍Promise

1.1 什么是Promise?

  1. 抽象表达: Promise 是一门新的技术(ES6 规范),Promise 是 JS 中进行异步编程的新解决方案.

  2. 具体表达:

    从语法上来说: Promise 是一个构造函数;

    从功能上来说: promise 对象用来封装一个异步操作并可以获取其成功/ 失败的结果值.

1.2 为什么要使用Promise?

  1. 指定回调函数的方式更加灵活

  2. 支持链式调用,可以解决回调地狱问题

    什么是回调地狱?

    回调函数嵌套调用, 外部回调函数异步执行的结果是嵌套的回调执行的条件.

在这里插入图片描述

1.3 怎么使用Promise?

举几个例子:

第一个例子 需求是: 点击按钮,1s后弹窗是否中奖(中奖的概率是30%)

<body>
    <h2>Promise 抽奖</h2>
    <hr>
    <button>点击我进行抽奖</button>

    <script>
        const btn = document.querySelector('button')
        function random (max,min){
            return Math.floor(Math.random()*(max-min+1)+min)
        }
        btn.addEventListener('click',()=>{
            /* 
                resolve 成功
                reject  失败
            */
          // 创建一个实例化对象
            const p = new Promise((resolve,reject)=>{
                setTimeout(() => {
                    let n = random(1,100)
                    if(n > 30)
                    {
                        // 将Promise对象的状态设置为成功(可以传递参数)
                        resolve(n); 
                    }else{
                        // 将Promise对象的状态设置为失败(可以传递参数)
                        reject(n);       
                    }
                }, 1000);
            })
            p.then((value)=>{
                //成功的回调
                alert('很遗憾,您没有中奖!再接再厉!'+ value)
            },(reason)=>{
                //失败的回调
                alert('恭喜您,获得50W!!' + reason)
            })
        })
    </script>
</body>
</html>

第二个例子 读取文件

const fs = require('fs')

const p = new Promise((resolve, reject) => {
    fs.readFile('D:\\vs code\\Promise\\book.txt', (err, data) => {
        if (err) {
            reject(err)
        }
        resolve(data)
    })

})

p.then((value) => {
    console.log(value.toString());
}, (reason) => {
    console.log(reason);
})

第三个例子 发送Ajax请求

<body>
    <h2>Promise 请求</h2>
    <hr>
    <button>点击我发送请求</button>
    <script>
        const btn = document.querySelector('button')
        btn.addEventListener('click', () => {
            const p = new Promise((resolve, reject) => {
                // 创建对象
                const xhr = new XMLHttpRequest();
                // 设置响应体的类型
                xhr.responseType = 'json'
                //初始化
                xhr.open('Get', 'http://poetry.apiopen.top/sentences');
                //发送
                xhr.send();
                //处理响应的结果
                xhr.onreadystatechange = function () {

                    if (xhr.readyState === 4) {
                        //先判断响应状态码
                        if (xhr.status >= 200 && xhr.status < 300) {
                            resolve(xhr.response.result.name);
                        } else {
                            reject(xhr.status);
                        }
                    }
                }
            })
            p.then((value) => {
                console.log(value);
            }, (reason) => {
                console.log(reason);
            })
        })
    </script>
</body>

第四个例子 封装Ajax请求

<!DOCTYPE html>
<html lang="en">

<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>
    <script>
        function sendAjax(url) {
            return new Promise((resolve, reject) => {
                //创建对象
                const xhr = new XMLHttpRequest();
                //设置响应体类型
                xhr.responseType = 'json';
                //初始化
                xhr.open('Get', url);
                //发送
                xhr.send();
                //处理响应结果
                xhr.onreadystatechange = function () {
                    if (xhr.readyState == 4) {
                        if (xhr.status >= 200 && xhr.status < 300) {
                            resolve(xhr.response.result.name);
                        } else {
                            resject(xhr.status);
                        }
                    }
                }
            })
        }

        sendAjax('http://poetry.apiopen.top/sentences').then((value) => {
            console.log(value);
        }, (reason) => {
            console.log(reason);
        })
    </script>
</body>

</html>

第五个例子 封装fs读取文件

function miniReadyFile (path){
    return new Promise((resolve,reject)=>{
        const fs = require('fs')
        fs.readFile(path,(err,data)=>{
            if(err) 
            {
                reject(err);
            }
            resolve(data)
        })
    })
}

miniReadyFile('D:/vs code/Promise/book.txt')
.then((value)=>{ 
    console.log(value.toString());
},(reason)=>{
    console.log(reason);
})

1.4 util.promisify

在这里插入图片描述

上图来着nodejs官网,简单来说:我们可以使用该模块帮助我们去封装成一个函数,当我们去调用这个函数的时候返回的是一个Promise对象,但是使用的时候有条件:需要是以错误优先的回调风格的函数.

例如:1.3 中第四个例子里的 fs (err,data)=>{}

// 导入 util
const util = require('util')

// 导入 fs
const fs = require('fs')

// 返回一个函数,调用这个函数返回的是一个promise对象
let miniReady = util.promisify(fs.readFile);

miniReady('D:/vs code/Promise/book.txt').then((value)=>{
    console.log(value.toString());
},(reason)=>{
    console.log(reason);
})

总结

以上就是今天要讲的内容,希望对大家有所帮助!!!

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

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/82913.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!