写点什么

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:005137
用户头像

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

关注

评论

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

基于品高基础云+容器云的DevOps双模应用探索

品高云计算

每日一题:LeetCode-718. 最长重复子数组

Geek_4z9ami

Go 面试 算法 LeetCode 动态规划

Java多线程系列8:JDK中的管程实现之条件变量

BigBang!

Java多线程

软件测试/测试开发丨测试用例价值与体系

测试人

软件测试 测试开发

学习贯彻“枫桥经验”,积极践行央企担当!

天翼云开发者社区

生态链 战略合作

SEO搜索引擎优化——被严重低估网络营销核心技能!

九凌网络

你知道海外云手机可以用于外贸测评吗?

Ogcloud

跨境电商 外贸

ETLCloud与简道云结合,实现企业信息同步

RestCloud

数据同步 ETL

引领汽车营销新趋势,3DCAT实时云渲染助力汽车三维可视化

3DCAT实时渲染

实时渲染 实时渲染云 汽车三维可视化

首批!天翼云大数据平台率先通过信通院无服务器架构大数据平台测试

天翼云开发者社区

云计算 大数据 架构 测试

海外云手机一般用来做什么?

Ogcloud

跨境电商

观点提炼 | 美国CISA、ODN等发布《SBOM推荐实践指南》

网安云

开源软件供应链 SBOM 软件供应链安全 开源软件供应链安全 软件物料清单(SBOM)

我对线上质量监控大盘的思考

老张

质量保障 质量度量 #监控

DAPP双币质押收益系统开发丨源码搭建

l8l259l3365

技术人必修课:利用金字塔原理高效思考与表达

阿里技术

思考 金字塔 技术人 表达 表达的逻辑

对于企业软件系统而言,唯一重要的架构设计是什么

FN0

架构 软件系统

软件测试/测试开发丨Linux 进程与线程

测试人

Linux 软件测试 测试开发

3分钟看懂如何给开源项目发起提案

伤感汤姆布利柏

Swagger 注解详述:如何编写更友好的API文档

Liam

后端 接口文档 API swagger 接口工具

除了增删改查,后端一定要学会这些!

伤感汤姆布利柏

后端 低代码

基于低代码平台开发应用程序

互联网工科生

软件开发 低代码 应用开发 可视化开发

杭州悦数成立「悦数图技术陆家嘴数据智能研究院」,入驻上海陆家嘴金融城「双城辉映」平台

悦数图数据库

分布式图数据库 图数据

亿级大表毫秒关联,荔枝微课基于腾讯云数据仓库Doris的统一实时数仓建设实践

腾讯云大数据

Doris

斩获冠亚军!开源检索引擎Puck闪耀NeurIPS'2023

百度Geek说

搜索引擎 开源 企业号12月PK榜

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