首页 > 其他分享 >Js 之promise、async 和 await

Js 之promise、async 和 await

时间:2023-07-31 16:44:42浏览次数:50  
标签:resolve console log await promise async

一、示例代码

<html>
<head></head>
<body>

<script src="jquery.js"></script>
<script>
    const login = async function(){
        var a = await new Promise((resolve, reject) => {
            $.get("", function(res){
                resolve(res);
            }, 'json');
        });
        console.log(a);
        var b = await test2();
        return b;
    }
    
    function test2(){
        return 'test2';
    }
    
    login().then(res => {
        console.log(res);
    });
</script>
</body>
</html>

二、promise

Promise 是承诺的意思,承诺它过一段时间会给你一个结果。Promise 是一种解决异步编程的方案,相比回调函数和事件更合理和更强大。从语法上讲,promise 是一个对象,从它可以获取异步操作的消息;

promise 有三种状态:pending 初始状态也叫等待状态,fulfiled成功状态,rejected 失败状态;状态一旦改变,就不会再变。创造 promise实例后,它会立即执行。需要注意,promise 的状态是不可逆的,一旦状态由 pending 变为 fulfiled 或者reject 状态,意味着已经产生了结果,同样,转为成功状态会有成功的结果,转为失败状态会返回失败的原因。

promise 作为构造函数,接收两个参数,分别是成功和失败的回调函数。

function sleep(second) {
  return new Promise((resolve, reject) => {
    setTimeout(() => resolve(), second * 1000);
  });
}
sleep(3)
  .then(() => {
    console.log("开始执行");
    return sleep(3);
  })
  .then(() => {
    console.log("第二次执行");
    return sleep(3);
  })
  .then(() => {
    console.log("第三次执行");
  });

 

then 捕获resolve回调

catch 捕获reject状态的回调

p.then((data) => {
  console.log("resolved", data);
}).catch((err) => {
  console.log("rejected", err);
});

三、async 

async是一个加在函数前的修饰符,被async定义的函数会默认返回一个Promise对象resolve的值。因此对async函数可以直接then,返回值就是then方法传入的函数。使用如下:

async function fun() {
    console.log(1);
    return 1;
}
fun().then(val => {
    console.log(val) // 1,1
})

四、await

await 也是一个修饰符,只能放在async定义的函数内。可以理解为等待。await 修饰的如果是Promise对象:可以获取Promise中返回的内容(resolve或reject的参数),且取到值后语句才会往下执行;如果不是Promise对象:把这个非promise的东西当做await表达式的结果。使用如下:

async function fun() {
    let a = await new Promise((resolve, reject) => {
        setTimeout(function () {
            resolve('setTimeout promise')
        }, 3000)
    })
    let b = await "表达式";
    let c = await function () {
        return '函数表达式'
    }()
    console.log(a, b, c)
}
fun(); // 3秒后输出:"setTimeout promise" "表达式" "函数表达式"

 

标签:resolve,console,log,await,promise,async
From: https://www.cnblogs.com/yang-2018/p/17593826.html

相关文章

  • AsyncTask的用法
    原文链接:   在开发Android应用时必须遵守单线程模型的原则:AndroidUI操作并不是线程安全的并且这些操作必须在UI线程中执行。在单线程模型中始终要记住两条法则: 2.确保只在UI线程中访问AndroidUI工具包      当一个程序第一次启动时,Android会同时启动一个对应......
  • asyncio之网络请求Aiohttp笔记(转)
    翻译:https://zhuanlan.zhihu.com/p/425059903作者:挂枝儿来源:知乎本文源自:4Buildingaconcurrentwebcrawler·PythonConcurrencywithasyncioMEAPV10​livebook.manning.com/book/concurrency-in-python-with-asyncio/chapter-4/v-10/主要介绍Python近年新出的协程......
  • JavaScript 中的Promise学习
     代码示例:<scripttype="text/javascript">newPromise(function(resolve,reject){console.log(111);resolve(222);}).then(function(value){console.log(value);......
  • 优化trycatch所需的前置知识点(Promise对象讲解)
    优化trycatch所需的前置知识点(Promise对象讲解):https://blog.csdn.net/weixin_45371730/article/details/122029631?spm=1001.2101.3001.6650.9&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-9-122029631-blog-119996003.235%5E......
  • Promise 中的异步错误 怎么捕获
    Promise中的异步错误怎么捕获:https://blog.csdn.net/liubangbo/article/details/128497218?ops_request_misc=&request_id=&biz_id=102&utm_term=promise%20%E5%BC%82%E5%B8%B8%E6%8D%95%E8%8E%B7&utm_medium=distribute.pc_search_result.none-task-blog-2~all~soba......
  • promise
    Promise.all是一个静态方法,用于处理多个Promise对象。它会接收一个Promise对象数组作为参数,返回一个新的Promise对象,该Promise对象在所有Promise对象已完成时才会完成,并携带着所有Promise对象完成的结果(按照Promise对象数组顺序)。以下是实现一个简单的Promise.al......
  • 手写一个Promise
    Promise背景JavaScript这种单线程事件循环模型,异步行为是为了优化因计算量大而时间长的操作。在JavaScript中我们可以见到很多异步行为,比如计时器、ui渲染、请求数据等等。Promise的主要功能,是为异步代码提供了清晰的抽象,支持优雅地定义和组织异步逻辑。可以用Promise表示异步......
  • WPF AsyncLocal 为 null 的错误 、 AsyncLocal 在WPF中的使用问题
    前言:  想载WPF中使用AsyncLocal下,发现这里面有个巨坑。参考链接  标题为AsyncLocalinWPFisnullafterfirstsetonthesamethread  AsyncLocl变量在程序初始化时设置,主窗口加载Load事件之前都还有,Load事件执行完后就,清空了ExecutionContext。示例  ......
  • Promise
    Promise是一种用于处理异步操作的对象(解决了回调地狱的问题)它有三种状态:pedding(进行中)    resolve(已成功)   rejected(已失败) pedding =>resolve 或 pedding=>rejected(状态一旦变更,就无法再次变更了,是什么就是什么了,板上钉钉)了解Promise前可以在......
  • async/await初学者指南
    JavaScript中的async和await关键字提供了一种现代语法,帮助我们处理异步操作。在本教程中,我们将深入研究如何使用async/await来掌控JavaScript程序中的流程控制。总览如何创建JavaScript异步函数async关键字await关键字声明异步函数的不同方式await/async内部机制从p......