TypeScript 1.3 发布: 支持 protected 访问修饰符和元组类型

  • 孙镜涛

2014 年 11 月 19 日

话题:语言 & 开发架构

Microsoft 已经发布了TypeScript 1.3,而这距离2.0 路线图的发布仅仅过去了 20 多天,虽然时间很短,但是新版本实现了路线图中提到的全部内容:语言层面支持“protected”访问修饰符以及元组类型,工具方面提供了更好的智能感知能力。

“protected”访问修饰符是开发者高度要求的功能特性,它能够让开发人员在 TypeScript 中使用更多的面向对象模式。例如,在下面这段代码中我们通过该修饰符让子类可以使用父类的 setElement 方法,但是其他部分的代码却根本不知道该方法的存在。

class List<T> {
    private contents: T[];
    constructor() {
        this.contents = [];
    }
protected setElement(index: number, item: T) {
this.contents[index] = item;
    }

}
class Stack<T> extends List<T> {
    currentIndex: number;
constructor() {
        super();
this.currentIndex = 0;
    }
    public push(item: T) {
this.setElement(this.currentIndex, item);
this.currentIndex++;
    }
}
var stack = new Stack<number>();
stack.setElement(0, 1); // error 'setElement' is protected and only visible to subclasses 

元组类型是语言层面的另一个特性,它能够让我们扩展现有的类型系统从而使用即将发布的ECMAScript 6 标准中包含的各种模式。通过元组类型,我们可以准确地描述混合类型数组中数据的类型,例如下面这个例子:

var tuple: [number, string] = [1, "bob"];
var secondElement = tuple[1];  // secondElement now has type 'string' 

在工具层面,TypeScript 1.3 基于 Roslyn 构建了一个新的 Visual Studio 2015 语言服务,借助于该服务用户能够更快、更精确地找到所有的引用;可以像 C# 那样使用“回车”或者“Tab”键从完成列表中提交选择。另外,新版本还增强了大纲和着色功能,并提升了 rename 的精度,为了更好地支持函数式编程风格,编辑器还改进了嵌套函数的处理机制。

TypeScript 1.3 已经内置到了 Visual Studio 2015 预览版中,但是如果你使用的是 Visual Studio 2013,那么可以通过工具安装NPM以及代码三种途径获取。


感谢崔康对本文的审校。

给 InfoQ 中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

语言 & 开发架构