【TypeScript】如何在TypeScript中使用async/await,让你的代码更像C#。

async/await

提到这个东西,大家应该都很熟悉。最出名的可能就是C#中的,但也有其它语言也实现。比如,Python 3.5中、比如Js中的yield/generator。

Typescript 当前版本1.8.x,1.7版本开始支持async/await, 当然只支持es6编译。2.1版本说是将支持到es5/es3.



Typescript Roadmap : https://github.com/Microsoft/TypeScript/wiki/Roadmap

优点

在这种方式之前,我们主要用的方式,就是回调方式。但如果,你的当前这个调用依赖于回调的数据,当这种关系依赖的多些时候,想想你的代码。

有了 async/await的方式,可以让异步的调用,用起来像同步一样。

场景

想一下这样的场景,有三个http请求,每一个都要依赖上一个请求的返回结果。

我们用js在node中,模拟一下这样的场景。

let http = require('http');

function test() {
http.get('http://www.baidu.com', function (res) {
console.log('the first Status :' + res.statusCode);
http.get('http://www.163.com', function (res2) {
console.log('the second Status :' + res2.statusCode);
http.get('http://www.sina.com', function (res3) {
console.log('the third Status :' + res3.statusCode);
})
})
});
} test();

我们再来看一下 Typescript 中,用 async/await 的方式。


import http = require('http'); class httpAsync {
constructor() { } public async GetAsync(url: string): Promise<http.IncomingMessage> {
var promise = new Promise<http.IncomingMessage>(resolve => {
http.get(url, res => {
resolve(res);
});
}); return promise;
}
} async function test() {
let ha = new httpAsync(); let res = await ha.GetAsync("http://www.baidu.com");
console.log('the first Status :' + res.statusCode);
res = await ha.GetAsync("http://www.163.com");
console.log('the first Status :' + res.statusCode);
res = await ha.GetAsync("http://www.sina.com");
console.log('the first Status :' + res.statusCode);
} test();

我们封装了一个httpAsync类,用async方式包装了一下,

对比一个 两个test方法内容,你觉得哪种方式更舒服一些。

如何实现

对C#熟悉的同学,可能很好的理解,因为Promise很像C#中的TaskCompletionSource<T>.

我们来一段 C# 模拟实现这个功能的, C#中的HttpClient本身是支持async/await模式的,大家不要纠结这个,这里只是模拟这个方式 .


public class HttpAsync
{
public Task<HttpResponseMessage> GetAsync(string url)
{
TaskCompletionSource<HttpResponseMessage> tcs = new TaskCompletionSource<HttpResponseMessage>(); HttpClient hc = new HttpClient(); hc.GetAsync(url).ContinueWith(res =>
{
tcs.SetResult(res.Result);
hc.Dispose();
}); return tcs.Task;
}
}

C# 这方面感兴趣的同学,可以去查查,网上的资料很多。

Typescript 实现这种方式,主要是一个关键字 async 和一个对象 Promise<T> .


import http = require('http'); class httpAsync {
constructor() { } public async GetAsync(url: string): Promise<http.IncomingMessage> {
var promise = new Promise<http.IncomingMessage>(resolve => {
http.get(url, res => {
resolve(res);
});
}); return promise;
}
}
  • 方法必须用 async 来标记。
  • 可以被 await 的方法必须有返回值 Promise<T> ,如果你的返回值是 void ,那么方法的返回值就是 Promise<void> .
  • Promise<T> 包装你的调用,当成功时调用__resolve__ 回调 结果Promise<T> ,来确定你的异步完成。
  • 可以在 Promise 构造中,再追加一个 reject 参数,来返回执行过程中的原因或错误。
  • Typescript 最终也会把 async/await 的方式编译成 js 中类似 yield/generator 的方式

总结

看看 C#Typescript 的代码,看起来很还是很像的吧。因为他们的老爹都是一个人, C# 之父也是 Typescript 他爹。

在C#中,我们可能已很熟悉这种方式了,但是在 js/ts 中,我们使用的还不多,而且它也不像C#中提供全面的支持库,使用的时候,可能还是得酌情处理。

【TypeScript】如何在TypeScript中使用async/await,让你的代码更像C#。的更多相关文章

  1. [C#] .NET4.0中使用4.5中的 async/await 功能实现异

    好东西需要分享 原文出自:http://www.itnose.net/detail/6091186.html 在.NET Framework 4.5中添加了新的异步操作库,但是在.NET Framew ...

  2. 在Silverlight中使用async/await

    现在 async/await 大行其道,确实,有了 async/await ,异步编程真是简单多了,个人觉得 async/await 的出现,给开发者还来的方便,绝不亚于当年 linq 的出现. 但要 ...

  3. 在现有代码中通过async/await实现并行

    在现有代码中通过async/await实现并行 一项新技术或者一个新特性,只有你用它解决实际问题后,才能真正体会到它的魅力,真正理解它.也期待大家能够多分享解一些解决实际问题的内容. 在我们遭遇“黑色 ...

  4. [C#] .NET4.0中使用4.5中的 async/await 功能实现异步

    在.NET Framework 4.5中添加了新的异步操作库,但是在.NET Framework 4.0中却无法使用.这时不免面临着抉择,到底是升级整个解决方案还是不使用呢? 如果你的软件还没发布出去 ...

  5. js循环中使用async/await踩过的坑

    最近写koa的时候遇见需要在循环中使用async/await的情况,当然第一反应就是直接上forEach,然后就直接翻车了... 直接上代码: function handleSql(val) { re ...

  6. 理解ES7中的async/await

    理解ES7中的async/await 优势是:就是解决多层异步回调的嵌套 从字面上理解 async/await, async是 "异步"的含义,await可以认为是 async w ...

  7. 浅谈C#中的 async await 以及对线程相关知识的复习

    C#5.0以后新增了一个语法糖,那就是异步方法async await,之前对线程,进程方面的知识有过较为深入的学习,大概知道这个概念,我的项目中实际用到C#异步编程的场景比较少,就算要用到一般也感觉T ...

  8. js中的async await

    JavaScript 中的 async/await 是属于比较新的知识,在ES7中被提案在列,然而我们强大的babel粑粑已经对它进行列支持! 如果开发中使用了babel转码,那么就放心大胆的用吧. ...

  9. .NET4.0中使用4.5中的 async/await 功能实现异步

    在.NET Framework 4.5中添加了新的异步操作库,但是在.NET Framework 4.0中却无法使用.这时不免面临着抉择,到底是升级整个解决方案还是不使用呢? 如果你的软件还没发布出去 ...

随机推荐

  1. 64位windows 7下成功配置TortoiseGit使用Github服务器

    最近感觉自己电脑上的代码太乱了,东一块.西一块……于是决定使用正规的源代码管理软件来管理自己以后写的代码.以前做小项目的时候用过TortoiseSVN,感觉不错,但是速度上有点慢,于是决定尝试一下新东 ...

  2. With语句以及@contextmanager的语法解析

    with 语句以及@contextmanager的语法解析   with语句可以通过很简单的方式来替try/finally语句. with语句中EXPR部分必须是一个包含__enter__()和__e ...

  3. 基类用的this指针

    结论:基类构造函数中的this指针指向的是派生类的对象 测试代码: #include <iostream> using namespace std; class father; fathe ...

  4. 总结最近移动端遇到的坑(auto-size + zepto)

    问题一:移动端页面双击会放大,图片时大时正常,布局偶尔很丑..刷新多遍又乜有问题 解决:所有图片设置宽高100%,最外面的html,给个 <meta name="viewport&qu ...

  5. cookie session URL重写 与考试

    状态管理.Cookie.Session.URL重写 HTTP协议:无状态的连接(每次连接都是新的请求)1.隐藏字段 <input type="hidden" name=&qu ...

  6. 运用requirejs的异步加载方式

    很容易让人以为是权重出问题了,但就我自己多个项目动画导出的经验来看,大 我们说程序员核心能力有以下几点:自学能力,解决问题的能力,团队合作能力.自学可以让我们在这个日新月异的时代不被淘汰;解决问题可以 ...

  7. Shell--用户配置

    vim /etc/profileexport PS1='\[\e[1;33m\]\h\[\e[m\] \t [\[\e[1;36m\]\w\[\e[m\]] [\u] '   export LANG= ...

  8. ARM11 S3C6410 硬件浮点(VFP)实现

    http://blog.csdn.net/liujia2100/article/details/7459683 在调试一个代码时,编译能顺利编过.可是,就是不能执行.找了半天才发现,原来是浮点问题.由 ...

  9. 工程BUG记录

    前天项目中,有个 id 对象,命名成了 initA...  从该页面点击进入其他时没有问题,但是在返回到该页面后,程序崩溃了,报了野指针,后来在跳转传值的时候,发现这个异常.我猜测原因可能是 xcod ...

  10. c# 筛选进程命令行,得其ProcessId(唯一标示符,简称pid),再通过pid结束进程

    不说别的,上代码 部分using: using System.Diagnostics; using System.Management; 其中要引用System.Management 1.通过筛选Co ...