温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Javascript怎么理解全国甲卷高考作文

发布时间:2022-06-09 09:21:26 来源:亿速云 阅读:138 作者:iii 栏目:开发技术

这篇文章主要介绍“Javascript怎么理解全国甲卷高考作文”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Javascript怎么理解全国甲卷高考作文”文章能帮助大家解决问题。

    场景:根据用户id(001),获取到用户姓名后,再获取用户性别,再获取用户年龄

    function getUserName(id, callback) {
        setTimeout(function () {
            callback('001姓名为鲨鱼辣椒')
        }, 1000)
    }
    function getUserSex(id, callback) {
        setTimeout(function () {
            callback('001性别为男')
        }, 1000)
    }
    function getUserAge(id, callback) {
        setTimeout(function () {
            callback('001年龄为5')
        }, 1000)
    }
    // 开始套娃
    getUserName('001', function (name) {
        console.log(name)
        getUserSex('001', function (sex) {
            console.log(sex)
            getUserAge('001', function (age) {
                console.log(age)
            })
        })
    })

    由上述代码可知,这种写法通常会饱受回调地狱的“折磨”,尤其是当依赖的请求变的越来越多时,我们的“屎山”也便一发不可收拾了。当Promise问世之后,我们来看看又该如何优化,而这一优化是不是也代表着“翼然”向“泻玉”所作出的转变呢?

    function getUserName(id) {
        return new Promise(function (resolve) {
            setTimeout(function () {
                resolve('001姓名为鲨鱼辣椒')
            }, 1000)
        })
    }
    function getUserSex(id) {
        return new Promise(function (resolve) {
            setTimeout(function () {
                resolve('001性别为男')
            }, 1000)
        })
    }
    function getUserAge(id) {
        return new Promise(function (resolve) {
            setTimeout(function () {
                resolve('001年龄为5')
            }, 1000)
        })
    }
    // 禁止套娃,一切都开始扁平了起来
    getUserName('001').then(function (data) {
        console.log(data)
        return getUserSex('001')
    }).then(function (data) {
        console.log(data)
        return getUserAge('001')
    }).then(function (data) {
        console.log(data)
    })

    由此可见,当应用了Promise之后,这座“屎山”也随之被铲平了。如果说then的链式调用足以磨平请求代码的“屎山”,那么我们今天用一个需求,来展现async降维打击的能力之强,下面我们开始逐渐处理并发请求,也一道解开“翼然”、“泻玉”、“沁芳”之间的关系

    回顾

    Promise

    Promise的特点是同步执行代码,且在未决议之前拥有三种状态:初始化状态为pending、成功状态为resolve、失败状态为rejected。在未调用resolve以及rejected之前,状态始终保持为pending,调用resolverejected后状态分别为成功/失败,要注意的是状态一旦确定,不可更改。每个Promise对象都会返回一个then方法,这个then方法会在Promise对象成功/失败时如期调用,因为这是Promise所作出的承诺,例如:

    var p = new Promise((resolve, rejected) => {
        // 1秒钟之后调用resolve,将初始化状态改为成功状态
        // 注意,在此1秒钟之前,p的状态始终为初始化状态,因为Promise尚未作出决议
        setTimeout(resolve, 1000)
    })
    // then方法会在约1秒钟后执行
    p.then(data => console.log(data))

    Promise.all

    all方法接收一个具有iterator接口的数据,例如数组。要注意的是这个数组中的每一个成员都必须是一个Promise对象,all方法会返回这些Promise对象成功或失败的值,例如:

    var p = async () =>  await new Promise(r => setTimeout(r, 1000))
    var f = Promise.all([p, p])
    // then方法会在约1秒钟后执行
    p().then(data => console.log(data))

    async

    async函数始终会返回一个Promise对象,这个Promise对象的状态取决于async函数的返回值。await关键字的职责就是异步求值,通常后面会是一个Promise对象,await关键字会“自动”帮我们then这个Promise对象,然后拿到数据进行返回。注意,只有当await后面的这个Promise对象决议了,async函数才会继续往下执行,否则交出线程转而执行其它任务,例如:

    // f会在约1秒钟后决议
    var f = async () =>  await new Promise(r => setTimeout(r, 1000))
    // then方法会在约1秒钟后执行
    f().then(data => console.log(data))

    需求

    回顾完成,接下来我们通过这个需求来解开“翼然”、“泻玉”、“沁芳”之间的关系。比如我有一个装有一百个书本id的数组,我需要获取每个书本的详细内容,虽然是一百本书,但由于只有一个接口,所以需要重复调用,只不过在调用时每次的入参id均不同而已

    实现

    准备准备

    数据

    books中存储着每个书本的id,我们需要通过这些枯燥无味的id来拿到每个书本所对应的信息

    var books = [
        {id: "0000"},
        {id: "1111"},
        {id: "2222"},
        {id: "3333"},
        // more...
    ]

    封装请求

    我们先封装一个request方法,用于请求单个书本id所对应的信息。因为没有这么合适的接口来供我们练习,所以此处暂时决定使用setTimeout来代替请求区域

    // request方法会在约1秒钟后“请求成功”
    var request = id => new Promise(resolve => setTimeout(resolve, 1000))

    原生

    通过xhr封装一个请求,要注意的是这里的请求函数requestJs并未用到Promise对象,而是使用了原汁原味的回调模式,因为在ES6之前Promise尚未面世,这也正对应了最开始的阶段——“翼然”

    var info = []
    var requestJs = (id, callback) => {
        var xhr = new XMLHttpRequest()
        open('GET', 'url')
        xhr.send(null)
        xhr.onreadyStatechange = function () {
            if (xhr.readyState == 4) {
                if (xhr.status >= 200 && xhr.status < 300) {
                    callback(xhr.responseText)
                }
            }
        }
    }
    // 通过定时器来模拟请求
    var requestJsPolyill = (id, callback) => {
        setTimeout(() => {
            callback(id)
        }, 1000)
    }
    var judge = data => {
        info.push(data)
        if (books.length === info.length) {
            console.log('请求到的数据:', info)
        }
    }
    books.forEach(v => requestJsPolyill(v.id, judge))

    Promise

    每请求到一个书本的信息就追加到info数组中,每次追加后,来判断booksinfo的长度是否相同,如果相同,则代表所有书本信息均已请求完毕,如果不同则代表尚有书本信息未请求成功,我们正是通过这种方式来处理并发请求,可以看到的是Promise这种方式正是对原生JS的一种化用,或者说是一种更好的改变,所以也就符合了“泻玉”这一阶段

    // 存储获取到的书本信息
    var info = []
    var f = new Promise(resolve => {
        books.forEach(v => {
            // 根据books中每个id进行请求
            request(v.id).then(() => {
                // 每请求到一个书本信息都会放在info中
                info.push(v.id)
                // 当请求完的信息数量与原始书本的数量对应起来时,则代表全部请求完成
                if (books.length === info.length) {
                    resolve(info)
                }
            })
        })
    })
    // 获取完全部书本信息后执行then方法
    f.then(data => {
        console.log('请求到的数据:', data)
    })

    async

    由于map方法会返回一个新数组,所以此处通过map来对books中的每一个书本id都加工成一个请求,通过request来完成这个请求,而request又会返回一个Promise对象,这样一来,返回的这个新数组中的每个成员就都是一个Promise对象,而Promise.all方法在接收到这个新数组后,会并发执行所有Promise对象,等到所有Promise对象都决议后,then方法才会被调用。使用async来完成这个需求,无论是代码简洁程度还是可读性,都大大的超越了“翼然”和“泻玉”这两个阶段,也可以说这正是“沁芳”的独特所在

    // 当新数组中的所有Promise全部决议后,then会被如期调用
    var f = Promise.all(books.map(async v => await request(v.id)))
    f.then(data => {
        console.log('请求到的数据:', data)
    })

    关于“Javascript怎么理解全国甲卷高考作文”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI