ES6-Promise简介、ES7 新特性及ES8新特性-async和await

ES6-Promise

Promise简介

Promise 是ES6引入异步编程的新解决方案。语法上Promise是一个构造函数,用来封装异步操作并可以获取其成功或失败的结果
通过new关键字可以实例化出一个Promise对象用法:

  • new Promise(excutor){}
    参数:
    excutor是一个这样的函数function(resolve, reject){}
    • resolve: resolve方法可以改变Promise实例对象的状态为 成功
    • reject:reject:方法可以改变promise实例对象的状态为 失败
// 实例化Promise对象
const p = new Promise(function(resolve, reject){
    // 封装异步操作
})

Promise.prototype.then方法

用法: p.then(function(value){}, function(){}}

  • promise对象then方法有两个函数为形参
  • promise对象状态为 成功时调用第一个函数,第一个函数也有一个形参value
  • value的值就是异步调用中由resolve方法返回的数据
  • promise对象状态为 失败时调用第二个函数,第二个函数也有一个形参reason
  • reason的值是异步调用中由reject方法返回的错误

成功的异步读取:

// 调用promise对象的then方法
p.then(function(value){
    console.log(value); // 用户数据
},function(reason){

})

失败的异步读取:

// 实例化Promise对象
const p = new Promise(function(resolve, reject){
    // 封装异步操作
    setTimeout(function(){
        let err = "读取失败";
        reject(err)
    })
})
// 调用promise对象的then方法
p.then(function(value){
    
},function(reason){
    console.error(reason); //读取失败
})

then方法返回结果
then方法返回结果也是一个Promise对象,对象的状态由回调函数的执行结果决定

  • 如果回调函数中返回的结果是非Promise类型的属性,状态为成功,返回值为对象的成功的值
// 实例化Promise对象
const p = new Promise(function (resolve, reject) {
    // 封装异步操作
    setTimeout(function () {
       	let data = "用户数据"
        resolve(data)
    })
})
// 调用promise对象的then方法
const result = p.then(function (value) {
    console.log(value);
    // 1.返回非Promise类型的属性,返回成功的Promise类型对象
    // return "iloveyou"
    // 2.返回Promise对象
     return new Promise((resolve, reject)=>{
        // 2.1 成功 返回成功的Promise类型对象
        resolve("成功!")
    //     // 2.2 失败 返回失败的Promise类型对象
    //     reject("失败!")
     })
    // 3.抛出错误 返回失败的Promise类型对象
    // throw new Error("出错啦")
}, function (reason) {

})

console.log(result);

在这里插入图片描述

Promise.prototype.catch方法

catch方法可以获取 Promise类型对象的状态为失败的值

  • 该方法等同于then方法的参数不写第一个回调函数的内容
    用法:
    p.catch(function(reason){})
// 实例化Promise对象
const p = new Promise(function (resolve, reject) {
    // 封装异步操作
    setTimeout(function () {
        // 设置p对象的状态为失败,并设置失败的值
        let err = "读取失败";
        reject(err)
    })
})

p.catch(function(reason){
    console.warn(reason);
})

在这里插入图片描述

ES7 新特性

Array.prototype.includes

includes方法用来检测数组中是否包含某个元素,返回布尔类型值

const arr = ["江流","心猿","木龙","刀圭","意马"];
console.log(arr.includes("心猿"));// true
console.log(arr.includes("蜘蛛精"));// false

指数操作符

在ES7中引入了指数运算符**,用来实现幂运算,功能与Math.pow()结果相同

console.log(5 ** 2);//25
console.log(2 ** 10);//1024

ES8新特性-async和await

async 和 await

ES8提出的async 和 await 关键字两种语法结合可以让异步代码像同步代码一样,可以解决promise对象不断使用then方法的代码不简洁问题

async函数

  • async函数的返回值为Promise类型对象
  • Promise类型对象的结果由async函数执行的返回值决定
    • 如果返回的结果不是一个Promise类型的对象,返回的结果就是状态 成功Promise对象
    • 如果返回的结果是一个Promise类型的对象,返回的结果Promise对象状态由返回的那个Promise类型的对象的状态决定,如果成功,返回的结果状态也是成功,失败则返回的结果状态也是失败,返回结果的值也是Promise类型的对象的值决定
async function fn() {
    // 1.返回非Promise类型的属性,返回成功的Promise类型对象
    // return "iloveyou"

    // 2.抛出错误 返回失败的Promise类型对象
    // throw new Error("出错啦")

    // 3.返回Promise对象
    return new Promise((resolve, reject) => {
        // 3.1 成功 返回成功的Promise类型对象
        resolve("成功!")
        //     // 3.2 失败 返回失败的Promise类型对象
        //     reject("失败!")
    })
}

const result = fn();
console.log(result);

在这里插入图片描述

await表达式

  • await关键字必须写在async函数中
  • await关键字右侧的表达式一般为promise对象
  • await返回的是promise成功的值
  • await表达式返回的promise成功的值
  • await表达式的promise状态失败了,就会抛出异常,需要通过try...catch捕获处理

await表达式状态成功时

// await 要放在async函数中
async function main() {
    let result = await new Promise((resolve, reject) => {
        resolve("用户数据");
    })
    // 打印await表达式返回值
    console.log(result);
}
// 调用函数
main()//用户数据

await表达式状态失败时,通过try...catch捕获处理

// await 要放在async函数中
async function main() {
    try {
        let result = await new Promise((resolve, reject) => {
            reject("读取失败")
        })
        // 打印await表达式返回值
        console.log(result);
    }
    catch (e) {
        console.warn(e);
    }
}
// 调用函数
main()

在这里插入图片描述

async和await结合读取文件

文件路径
在这里插入图片描述
JS代码

// 引入fs文件模块
const fs = require("fs");

// 读取《登鹤雀楼》
function readPoetry(){
    return new Promise((resolve, reject)=>{
        fs.readFile("./resource/登鹳雀楼.md", (err, data)=>{
            if(err){
                reject(err)
            }else{
                resolve(data)
            }
        })
    })
}
// 读取译文
function readTranslation(){
    return new Promise((resolve, reject)=>{
        fs.readFile("./resource/译文.md", (err, data)=>{
            if(err){
                reject(err)
            }else{
                resolve(data)
            }
        })
    })
}
// 读取创作背景
function readBackground(){
    return new Promise((resolve, reject)=>{
        fs.readFile("./resource/创作背景.md", (err, data)=>{
            if(err){
                reject(err)
            }else{
                resolve(data)
            }
        })
    })
}
// 声明一个async函数
async function main(){
    //获取《登鹤雀楼》内容
    let poetry = await readPoetry();
    // 获取 译文内容
    let translation = await readTranslation();
    // 获取 创作背景内容
    let background = await readBackground();
    console.log(poetry.toString());
    console.log(translation.toString());
    console.log(background.toString());
}
// 执行main函数
main()

执行结果
在这里插入图片描述

async和await结合发送AJAX请求

代码


    <script>
        // 发送AJAX请求,返回是Promise对象
        function sendAJAX(url) {
            return new Promise((reslove, reject) => {

                // 1.创建AJAX对象
                const xhr = new XMLHttpRequest();

                // 2.初始化
                xhr.open("GET", url);

                // 3.发送
                xhr.send();

                // 4.事件绑定
                xhr.onreadystatechange = function () {
                    if (xhr.readyState === 4) {
                        if (xhr.status >= 200 && xhr.status < 300) {
                            // 成功
                            reslove(xhr.response);
                        }else{
                            // 失败
                            reject(xhr.status)
                        }
                    }
                }
            })
        }
        // 测试
        async function main(){
            // 发送AJAX请求
            let data = await sendAJAX("https://api.apiopen.top/getJoke");
            console.log(data);
        }
        main()
    </script>

效果
在这里插入图片描述

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ES6-ES12是JavaScript的不同版本,每个版本都引入了新的特性和改进。以下是一些ES6到ES12的新特性的示例: ES6(2015年): 1. 箭头函数:简化了函数的语法。 2. 模板字面量:使用反引号(`)来创建多行字符串和插入变量。 3. 解构赋值:从对象或数组提取值并赋给变量。 4. let和const:引入块级作用域的变量声明方式。 5. Promise:处理异步操作的更强大的方式。 ES7(2016年): 1. Array.prototype.includes():判断数组是否包含某个元素。 2. 指数操作符:使用双星号(**)进行指数运算。 ES8(2017年): 1. async/await:更简洁地处理异步操作。 2. Object.values()和Object.entries():从对象提取值或键值对。 ES9(2018年): 1. Rest/Spread属性:通过...语法来处理函数参数和对象字面量。 2. Promise.prototype.finally():在Promise结束时执行操作。 ES10(2019年): 1. Array.prototype.flat()和Array.prototype.flatMap():用于处理嵌套数组的方法。 2. Object.fromEntries():将键值对列表转换为对象。 ES11(2020年): 1. 可选链操作符(Optional chaining):简化了访问深层嵌套属性的方式。 2. Nullish coalescing操作符:提供了一种默认值的设定方式。 ES12(2021年): 1. Promise.any():在多个Promise返回最快解决的结果。 2. Logical Assignment Operators:提供了逻辑运算符与赋值的结合方式。 当然,以上仅是一些主要的新特性ES6-ES12还有其他许多有用的功能和语法改进。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值