700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > es7 async await定义异步函数执行同步操作

es7 async await定义异步函数执行同步操作

时间:2022-08-02 21:53:16

相关推荐

es7 async await定义异步函数执行同步操作

ES7 async定义函数1、可以在不阻塞主线程的情况下,使用同步代码实现异步访问资源的能力,让我们的代码逻辑更清晰2、await Promise.resolve(内容); 返回值为resolve的参数;reject(内容)函数调用会报错,内容为reject中的参数语法:async function 函数名(){await 异步操作await 异步操作}async:使得修饰的函数返回值为一个Promise对象,返回的Promise对象的结果和状态由函数返回值决定,同.then返回效果相同await:(1)await 后面不是Promise会直接返回,不会阻塞线程(2)必须在async函数中使用,而async函数中不一定需要await(3)只能获取成功状态的Promise结果,失败状态需要try-catch捕捉await Promise对象; 返回Promise对象的成功状态的值await 普通值; 返回普通值

代码示例:

html文件:

<html ng-app='app' ng-controller='main' ><head><meta charset="utf-8"><meta name='viewport' content='width=device-width,user-scalable=no,initial-scale=1.0,maximum-scale=1.0,minimum-scale=1.0'><script src='jq/jquery-3.4.1.js'></script><style></style></head><body ><script>async function fun(){return new Promise(resolve=>{setTimeout(resolve,2000);})}async function fun2(){console.log('开始',new Date().toTimeString());await fun();//会两秒后再打印console.log('结束',new Date().toTimeString());}fun2();function fun4(){return 'jeff';}async function fun3(){let res=await fun4();let res2=await Promise.resolve('promise')console.log(res);console.log(res2);}fun3();//发送ajax请求async function getNews(url){return new Promise((resolve,reject)=>{$.ajax({method:'GET',url:url,dataType:'json',success:function(res){resolve(res);}})})}async function sendXml(){let res=await getNews('http://localhost:3000/news?id=2');console.log(res);let res2=await getNews('http://localhost:3000'+mentsUrl);console.log(res2);}sendXml();</script></body></html>

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。