DDR爱好者之家 Design By 杰米
关键词:async 、await、promise
这三个东西 可以优雅的解决异步问题。在学习koa2的时候遇到了获取数据后再进行模板渲染的异步问题。在查找各种资料后成功的解决了该问题,现在写个笔记记录一下。
先说一下async、await,第一次见到这两个词是在学习vue的时候。因为前端在写代码的时候经常的会遇到向后台请求数据这样的场景,等待数据返回才可以进行下一步的操作。这就不得不处理异步这种情况。
async、await基本的语法就是:
let asyncFn = async()=> { let data = null; data = await getData(url);//getData()返回的数据是 {name:'my name is data!'} console.log(data.name);//打印出的是my name is data! }
getData();为一个封装了请求数据的方法;
如果不处理异步的情况:
let notAsyncFn =()=> { let data = null; data = getData(url);//getData()返回的数据是 {name:'my name is data!'} console.log(data.name);//打印出的是undefined; 因为data此时还是null; }
await 命令后面的 函数返回的是一个Promise 对象,运行结果可能是 rejected,所以最好把 await 命令放在 try...catch 代码块中。
getData函数的代码:
var getData = function (url){ console.log("get start"); console.log(url); return new Promise(function (resolve, reject) { //下面的request()方法 是nodeJS的request模块; request(url, function (error, response, body) { if (!error && response.statusCode == 200) { resolve(response.body); }else{ //throw new Error(response.statusText) reject('===error==='); } }); }) console.log("get end"); }
promise的相关介绍可以移步 大白话讲解Promise(一)
还有await 命令只能用在 async 函数之中,如果用在普通函数,就会报错。
koa2中具体的代码:
/** * koa2路由代码 */ //引入router模块 var router = require('koa-router')(); //引入server模块 封装的请求函数 var server = require('../server'); //url 是假的额 写的百度的网址 const url = 'www.baidu.com'; router.get('/',async function (ctx,next){ var data = await server.get(url); console.log('======data====='); console.log(data); await ctx.render('myPage',{ title: '123wangcong', data: data }) }); module.exports = router;
/** * server模块的代码 */ node的request模块 var request = require('request'); module.exports = { get : function (url){ console.log("get start"); console.log(url); return new Promise(function (resolve, reject) { request(url, function (error, response, body) { if (!error && response.statusCode == 200) { resolve(response.body); }else{ //throw new Error(response.statusText) reject('error==='); } }); }) console.log("get end"); } }
把package也贴出来
{ "name": "koa2-demo", "version": "0.1.0", "scripts": { "start": "NODE_ENV=development ./node_modules/.bin/nodemon bin/run", "test1": "NODE_ENV=test ./node_modules/.bin/nodemon bin/run", "koa": "./node_modules/.bin/runkoa bin/www", "pm2": "pm2 start bin/run ", "test": "./node_modules/.bin/mocha -u bdd" }, "dependencies": { "co": "^4.6.0", "debug": "^2.2.0", "ejs": "^2.5.6", "jade": "~1.11.0", "koa": "^2.0.0", "koa-bodyparser": "^2.0.1", "koa-convert": "^1.2.0", "koa-json": "^1.1.1", "koa-logger": "^1.3.0", "koa-onerror": "^1.2.1", "koa-request": "^1.0.0", "koa-router": "^7.0.0", "koa-static": "^1.5.2", "koa-views": "^5.0.1", "runkoa": "^1.5.2" }, "devDependencies": { "mocha": "^2.4.5", "nodemon": "^1.9.1", "should": "^8.3.0", "supertest": "^1.2.0" } }
哦对了 async函数里可以多次使用await 语句,我以为只能用一次await!!!并不是的!!!!
async更详细的介绍可以 看这里 阮一峰async 函数的含义和用法
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月25日
2024年11月25日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]