

class StateHandler extends class { reset() { return true; } } { constructor() { super(); } } var g = new StateHandler(); g.reset();这个类可以是匿名的,但仍然有和类声明的相同的功能。 3.User defined type guards 在早期的TypeScript中,用户可以使用if语句来限定类型,比如:
if (typeof x === "Number") { … }在新版本中,用户可以定义自己的类型,如:
interface Animal {name: string; } interface Cat extends Animal { meow(); } function isCat(a: Animal): a is Cat { return a.name === 'kitty'; } var x: Animal; if(isCat(x)) { x.meow(); // OK, x is Cat in this block }这样,在编码的时候不仅可以使用typeof和instanceof这检查类型,还可以使用接口来作自定义分析。Guard函数使用"a is X"来返回类型。 4.Intersection types(交叉类型) JS中常见的模式并不能容易地在现有类的新方法上表达出TypeScript的扩展性。为了实现,TypeScript新增了运算符'&'来合并两种类型。这个新的运算符‘&’称为交叉,它会创建一个司法局匿名的合并类型。
function extend<T, U>(first: T, second: U): T & U { let result = <T & U> {};| for (let id in first) { result[id] = first[id]; } for (let id in second) { if (!result.hasOwnProperty(id)) { result[id] = second[id]; } } return result; } var x = extend({ a: "hello" }, { b: 42 }); x.a; // works x.b; // works5.Abstract classes(抽象类) 和接口的使用有些相似的地方,抽象类允许你创建一个基类。
abstract class A { foo(): number { return this.bar(); } abstract bar(): number; } var a = new A(); // error, Cannot create an instance of the abstract class 'A' class B extends A { bar() { return 1; } } var b = new b(); // success, all abstracts are defined6.Generic type aliases(泛型类型别名) TypeScript 1.6允许使用泛型别名,如:
type switcharoo<T, U> = (u: U, t:T)=>T; var f: switcharoo<number, string>; f("bob", 4);
版权声明:本作品系原创,版权归码友网所有,如未经许可,禁止任何形式转载,违者必究。
发表评论
登录用户才能发表评论, 请 登 录 或者 注册