async/await的使用
更新日期:
本文简单介绍async
/await
,主要结合一个图片上传的场景进行使用。
有关async
/await
的出现,缘由可以跟随着Generator -> Promise -> 回调函数噩梦(callback hell) -> 异步 -> 单线程的javascript
这样的js倒序发展,一直追溯到javascript的出生。这里面的故事多着,这里主要针对async
/await
的使用进行介绍。
async/await
介绍
有关async
/await
的出现和原理这里不做详细解释,感兴趣的小伙伴们可以参考:
总之一句话总结:async
函数就是Generator
函数的语法糖。async
函数的实现,就是将Generator
函数和自动执行器,包装在一个函数里。
使用场景
同步的写代码方式的确会轻松的,加上如今webpack
、babel
等工具的普及,写代码可以是一件很舒服很享受的事情了。
常见的使用场景包括:
- 文件、图片的读取等待
- http请求的等待
- 串行http请求的处理
其实,在javascript中涉及到异步回调的处理,都可作为合适的使用场景。下面我们来针对一个图片的处理场景具体说明。
图片的上传和处理
场景
首先介绍一下需求场景:
- 从编辑器插件中获取到用户上传的图片,为一组的
base64
数据,即['base64-1', 'base64-1', ..., 'base64-n']
的数据。 - 需要将每个
base64
通过接口上传到服务器,同时拿回一个图片url
地址。 - 获取每个图片的大小,通过参数的方式添加到
url
的尾部(别处需要用到该数据)。 - 将最后的
['url-1?width=x&height=x', 'url-1?width=x&height=x', ..., 'url-n?width=x&height=x']
传给后台保存。
需要注意的地方是:
await
操作符用于等待一个Promise
对象,所以我们需要返回一个Promise
对象用于等待。await
只能在异步函数async function
中使用。
获取图片宽高
图片的加载是个异步的过程,我们来实现一个获取图片宽高的Promise
:
1 | // 获取图片宽高 |
这样,我们可以通过await getImgSize(url)
的方式,来同步获取图片大小。
上传图片并添加宽高参数
同样的,上传图片ajax服务也是异步过程,同时需要判断该内容是否base64
(编辑状态下,为已处理的url
格式)。
1 | // 上传图片 |
并行处理多个图片
上面,我们已经完成了单个图片的上传+大小获取了。现在我们来做最后的一步,同时处理一组的图片:
1 | async function uploadImageList(list) { |
我们在使用async
/await
的时候,需要进行异常的捕获和处理,这里只做了最简单的处理。
结束语
这里只介绍了简单的async
/await
使用,其他的像解构、Promise
、拓展等,当习惯了这些语法糖之后,写码的幸福指数会有很大提升。
码生艰难,写文不易,给我家猪囤点猫粮了喵~
查看Github有更多内容噢:https://github.com/godbasin
更欢迎来被删的前端游乐场边撸猫边学前端噢
如果你想要关注日常生活中的我,欢迎关注“牧羊的猪”公众号噢