写点什么

TypeScript 2.7 版本发布

  • 2018-02-05
  • 本文字数:1596 字

    阅读完需:约 5 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

TypeScript 2.7 版本已经发布了,新增了几个主要功能特性并进行了一些 bug 的修正。其中一些亮点包括对类属性的赋值检查、固定长度的元组和改进对象文字的类型推断。总的来说,这个版本对类型系统、ES2015+ 特性和总体的 TypeScript 开发者体验都进行了改进优化。

TypeScript 2.7 版本引入了一些突破性的改变,开发人员在升级代码库以使用 TypeScript 2.7 时,应该知晓这些变化。

当被问及 TypeScript 目前的版本规划时,项目经理 Daniel Rosenwasser 说:

我认为,从最广泛的意义上来说,我们关注的是易用性,并确保我们现有的用户继续在 TypeScript 上的投入是有价值的。前者通常是减少在起步时的学习成本,后者通常关注的是表现性及安全性。

例如,现有的 TypeScript 用户要求对类初始化进行更严格的检查。继 TypeScript 2.6 版添加了严格的函数类型检查之后,2.7 版本又添加了在类中使用strictPropertyInitialization 标志的严格属性初始化检查。这个标志会检查类的每个实例的属性,确定它是在类的构造方法里被初始化的,还是通过属性初始化程序初始化的。当升级到2.7 后,使用严格标记的开发人员将会自动地在他们的源代码中获得这个额外的检查。建议在TypeScript 中使用这一严格的标记,因为它可以帮助开发人员找到并消除其他类型的错误或异常行为。

明确的赋值断言功能也已经可用了,即使在TypeScript 分析器不能确认赋值时,也可以指示TypeScript 的控制流分析器始终认定一个明确已赋值的。

TypeScript 的设计师之一 Anders Hejlsberg 表示,版本还改进了对对象字面量的类型推断

改进在相同上下文中出现的多个对象字面量的类型推断。当多个对象字面量类型组成一个 union 类型时,我们将对象字面量类型规范化,这样所有的属性就会出现在 union 类型的每个组成部分中。

复制代码
const obj = test ? { text: "hello" } : {}; // { text: string } | { text?: undefined }
const s = obj.text; // string | undefined

第一行我们推断出 obj 的类型{},第二行随后导致了错误,因为 obj 似乎没有属性。这显然并不是理想的效果。

其他语言级别的改进包括改进union 类型和instanceof 表达式中结构相同类的处理方法,以及从操作符中推断出更好的类型保护

TypeScript 2.7 也对 ES2015+ 符号进行了改善支持。属性可以使用const 声明的符号来命名,可以在接口、类或类型文字中将Identifier 或PropertyAccessExpression 用作计算属性名称的一部分。

改进了与CommonJS 模块的互操作性,支持 import d from “cjs”,并使用了esModuleInterop 标志。在内部, TypeScript 利用了 CJS 模块的 ES 模块。Rosenwasser 向 InfoQ 解释了这项功能背后的动机:

我们知道在模块互操作性策略中存在一些不友好性,这使得一些用户更难以掌握 TypeScript。对于新 TypeScript 用户来说,这是一个障碍,这也是为什么我们要在这个版本中提高 esModuleInterop 标记优先级的原因。当然,我们也有参与对 ECMAScript 标准的更新,并且在发展我们语言时也非常注意吸收这些标准。

第三阶段的数字分隔符提议,预计将作为ES2018 的一部分,现在已经包含在TypeScript 中,帮助TypeScript 保持当前对JavaScript 语言的年度更新。

在TypeScript 2.7 中,有一些改进是针对开发人员使用体验的。像webpack 和Gulp 这样的开发工具将从新的增量构建编译器API 中受益。这一变化将使工具更容易地进行因更新代码带来的资源更新,而不是需要在每次增量更新中重新构建整个项目。此外,ide 还提供了一个更新的TypeScript 语言服务API,允许开发人员自动修复文件中所有已明确的问题

TypeScript 2.7 可以通过 npm 的 npm install -g typescript 命令进行安装,或通过 GitHub 获得。TypeScript 2.8 开发工作已经在进行中,预计将于 3 月下旬发布。

英文原文链接 TypeScript 2.7 Now Available

2018-02-05 18:002591

评论

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

fastposter v2.12.0 ChatGPT都推荐的海报生成器

物有本末

fastposter 海报生成器 海报生成

那些高级前端是如何回答面试题的

Geek_02d948

JavaScript 前端

2023年:我成了半个外包

Java 架构

JS词法环境和执行上下文

hellocoder2029

JavaScript 前端

python+requests+excel+unittest+ddt接口自动化数据驱动并生成html报告(优化版)

Python 单元测试 自动化测试 unittest 测试框架

大模型时代的异构计算平台

Baidu AICLOUD

大模型训练 异构计算

开发一款wordpress插件并发布到官方插件库完全指南,小白也可以

咖啡教室

Selenium启动IE11常见问题解决方法

自动化测试 selenium IE

使用一个文件集中管理你的 Nuget 依赖版本号

newbe36524

C# Docker Kubernetes

CDR2023新功能抢先看

茶色酒

cdr2023

会声会影2023官方试用版更新下载功能详细介绍

茶色酒

会声会影2023

Node.js实现大文件断点续传

coder2028

JavaScript 前端

火山引擎推出一站式小程序监控方案

字节跳动终端技术

产品经理,项目经理,FTO

laofo

DevOps cicd 敏捷开发 研发效能 持续交付

一文读透react精髓

xiaofeng

前端 React

Vue模板是怎样编译的

yyds2026

Vue 前端

字节前端二面高频vue面试题整理

yyds2026

Vue 前端

Corel VideoStudio会声会影2023中文语言版本

茶色酒

会声会影2023

2023-02-23:请用go语言调用ffmpeg,解码mp4文件并保存为YUV420P格式文件。

福大大架构师每日一题

golang ffmpeg 福大大

LeetCode题解:633. 平方数之和,双指针,JavaScript,详细注释

Lee Chen

JavaScript 算法 LeetCode

Jmeter安装配置详细教程

Jmeter 性能测试 接口测试

前端一面必会面试题(边面边更)

coder2028

JavaScript 前端

秒懂算法 | 基于朴素贝叶斯算法的垃圾信息的识别

TiAmo

机器学习 算法 过滤算法

用es6的class类单例模式封装canvas环形进度条

咖啡教室

走进RocketMQ(一)整体架构与设计

白裤

Java RocketMQ RocketMQ整体架构 RocketMQ设计

基于selenium的UI自动化实践

Python 自动化测试 selenium

设计模式第八讲:观察者模式和中介者模式详解

C++后台开发

数据结构 设计模式 后端开发 Linux服务器开发 C++开发

会声会影2023简体中文试用版下载

茶色酒

会声会影2023

Window 的 PHP XAMPP 安装 mongodb 的扩展

HoneyMoose

Continuous profiling 拯救了 Victoria Metrics

golang 性能优化 可观测性 Prometheus 性能分析

Pycharm+PyQt5+Python3.5开发环境配置(详细教程)

Python pycharm 环境安装 PyQt PyQt5

TypeScript 2.7 版本发布_JavaScript_Dylan Schiemann_InfoQ精选文章