写点什么

TypeScript 1.7 发布:支持 async/await、模块化、多态 this 和求幂语法

  • 2015-12-04
  • 本文字数:1708 字

    阅读完需:约 6 分钟

伴随着 Visual Studio 2015 Update 1 的发布,TypeScript 1.7 也发布了,新版本默认支持 ES6 (ECMAScript 6) 的 async/await 以及模块化特性,支持多态“this”类型,支持 ECMAScript 2016 提出的求幂语法。详细的变更列表,可以查看 GitHub 上的路线图

和之前一样,用户可以通过 Visual Studio 2015 Update 1 Visual Studio 2013 NPM 或者直接通过源码来使用 TypeScript 1.7 。

Async/Await

在 1.7 版本中,用户能够在启用了 ES6 Generator 支持的目标上(例如 Node.js V4 及更高版本)使用 async 函数。而使用了 async 前缀的函数是异步函数,开发者可以在程序中使用 await 关键字来停止异步函数的执行,直到约定被满足为止。示例如下:

重要通知:接下来 InfoQ 将会选择性地将部分优秀内容首发在微信公众号中,欢迎关注 InfoQ 微信公众号第一时间阅读精品内容。

复制代码
"use strict";
// printDelayed is a 'Promise<void>'
async function printDelayed(elements: string[]) {
for (const element of elements) {
await delay(200);
console.log(element);
}
}
async function delay(milliseconds: number) {
return new Promise<void>(resolve => {
setTimeout(resolve, milliseconds);
});
}
printDelayed(["Hello", "beautiful", "asynchronous", "world"]).then(() => {
console.log();
console.log("Printed every element!");
});
</void></void>

Microsoft 正在努力将 TypeScript 中的 async/await 支持扩展到其他领域,包括浏览器这一并不支持 ES6 Generator 的领域。如果想要了解 async/await 的实现细节以及使用方法,可以查看博文《什么是 Async/Await》

多态 this 类型

在经过了大量的社区讨论和反馈之后,TypeScript 1.7 增加了一个新的多态 this 类型。开发者能够在类和接口中使用 this 类型,以表示某些类型是包含类型的子类型(而不是包含类型本身)。该特性能够让层级流式 API 这样的模式更加容易表达。

复制代码
interface Model {
setupBase(): this;
}
interface AdvancedModel extends Model {
setupAdvanced(): this;
}
declare function createModel(): AdvancedModel;
newModel = newModel.setupBase().setupAdvanced(); // fluent style works

如果想深入了解该关键字,可以查看 TypeScript Wiki

作为支持该特性的一部分,TypeScript 1.7 修改了 this 的类型推理逻辑。在一个类中,值 this 的类型将会被推断为 this 类型,用后续的原始类型值赋值会失败。作为一种替代方法,用户可以为 this 添加一个类型注解。使用替代方法的代码示例以及其他可能的重大变化可以查看GitHub。

ES6 模块

TypeScript 1.7 将 ES6 添加到了选项列表中,开发者能够使用–module 标记,当目标为 ES6 的时候指定模块化输出。这一特性为用户提供了更多的扩展性,让用户能够针对具体的运行时精确地指定特性。例如,现在能够以 Node.js v4 为目标,它并不支持 ES6 模块,但是支持一些其他的 ES6 特性。

复制代码
//tsconfig.json targeting node.js v4 and beyond
{
"compilerOptions": {
"module": "commonjs",
"target": "es6"
}
}

ES7 求幂运算

最后是一个小语法糖。ECMAScript 委员会最近将求幂运算符提议移动到了第三阶段。对于 Microsoft 来说这表示在 TypeScript 中采纳该特性的时机已经成熟,于是在 TypeScript 1.7 中添加了对它的支持。

复制代码
let squared = 2 ** 2; // same as: 2 * 2
let cubed = 2 ** 3; // same as: 2 * 2 * 2
let num = 2;
num **= 2; // same as: num = num * num;
Say goodbye to Math.pow()!

下一步计划

虽然 Microsoft 非常愉快地宣布了他们在该版本中做的所有提升,但是 Microsoft 也一如既往地关注社区的反馈。如果你对 TypeScript 的未来非常关注,那么 Microsoft 非常鼓励你检出已有的问题给他们提出pull request ,或者在 Gitter 上与 TypeScript 团队交流。


感谢徐川对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群(已满),InfoQ 读者交流群(#2))。

2015-12-04 18:005357
用户头像

发布了 321 篇内容, 共 134.4 次阅读, 收获喜欢 19 次。

关注

评论

发布
暂无评论
发现更多内容

【报名】飞桨中国行丨企业零门槛AI创新应用-智能制造专场

百度大脑

人工智能

Vue进阶(九十):过滤器

No Silver Bullet

Vue 9月日更

Go 专栏|基础数据类型:整数、浮点数、复数、布尔值和字符串

AlwaysBeta

Go 语言

Go 专栏|复合数据类型:字典 map 和 结构体 struct

AlwaysBeta

Go 语言

Go 专栏|接口 interface

AlwaysBeta

Go 语言

【Vue2.x 源码学习】第四十三篇 - 组件部分 - 组件相关流程总结

Brave

源码 vue2 9月日更

Electron团队为什么要干掉remote模块

刘晓伦

Electron Node

HTTP系列之:HTTP中的cookies

程序那些事

Java 网络协议 HTTP cookies

模块(二)如何设计架构

我是一只小小鸟

未来10年,5个C/C++吃香的细分领域技术

奔着腾讯去

云原生 网络安全 音视频 DPDK 虚拟化技术

Linux之lastlog命令

入门小站

Linux

【Flutter 专题】58 图解 Flutter 嵌入原生 AndroidView 小尝试

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 9月日更

【HTML5游戏】从敲打空格键开始

devpoint

HTML5游戏 9月日更

Go 专栏|变量和常量的声明与赋值

AlwaysBeta

Go 语言

从一个并发异常问题引起的想法

卢卡多多

并发编程 9月日更

升级mysql-connector-java-8.x踩坑纪实

小江

Java MySQL 时间戳 服务器时区 夏令时

LeetCode刷题278-简单-第一个错误版本

ベ布小禅

9月日更

Go 专栏|复合数据类型:数组和切片 slice

AlwaysBeta

Go 语言

Go 专栏|函数那些事

AlwaysBeta

Go 语言

Go 专栏|错误处理:defer,panic 和 recover

AlwaysBeta

Go 语言

在线JSON转JAVA工具

入门小站

工具

【LeetCode】 二叉树中和为某一值的路径Java题解

Albert

算法 LeetCode 9月日更

链路压测中各接口性能统计

FunTester

性能测试 测试框架 测试开发 FunTester 链路测试

Go 专栏|流程控制,一网打尽

AlwaysBeta

Go 语言

线程同步类CyclicBarrier在性能测试集合点应用

FunTester

多线程 性能测试 线程安全 测试框架 FunTester

Linux内核四大核心框架

hanaper

(深入篇)漫游语音识别技术—带你走进语音识别技术的世界

RTE开发者社区

深度学习 音视频 语音识别

Go 专栏|说说方法

AlwaysBeta

Go 语言

多线程知识体系01-线程池源码阅读讲解-Executor

小马哥

多线程 高并发 源码阅读 源码剖析 日更

Java + opencv 实现图片修复(图片去水印)

张音乐

Java OpenCV 音视频 9月日更 图片去水印

ShardingSphere 语句解析生成初探

源码 ShardingSphere

TypeScript 1.7发布:支持async/await、模块化、多态this和求幂语法_语言 & 开发_孙镜涛_InfoQ精选文章