TypeScript 是面向对象的 JavaScript。
类描述了所创建的对象共同的属性和方法。
TypeScript 支持面向对象的所有特性,比如 类、接口等。
TypeScript 类定义方式如下:
class class_name { 
    // 类作用域
}定义类的关键字为 class,后面紧跟类名,类可以包含以下几个模块(类的数据成员):
实例
创建一个 Person 类:
编译以上代码,得到以下 JavaScript 代码:
JavaScript
varPerson = (function(){functionPerson(){}returnPerson;
}());
创建类的数据成员
以下实例我们声明了类 Car,包含字段为 engine,构造函数在类实例化后初始化字段 engine。
this 关键字表示当前类实例化的对象。注意构造函数的参数名与字段名相同,this.engine 表示类的字段。
此外我们也在类中定义了一个方法 disp()。
TypeScript
classCar{engine:string; 
 
    constructor(engine:string){this.engine = engine}disp():void{console.log("发动机为 :   "+this.engine)}}
编译以上代码,得到以下 JavaScript 代码:
JavaScript
varCar = (function(){functionCar(engine){this.engine = engine;
    }Car.prototype.disp = function(){console.log("发动机为 :   " + this.engine);
    };
    returnCar;
}());
创建实例化对象
我们使用 new 关键字来实例化类的对象,语法格式如下:
var object_name = new class_name([ arguments ])
类实例化时会调用构造函数,例如:
var obj = new Car("Engine 1")类中的字段属性和方法可以使用 . 号来访问:
// 访问属性
obj.field_name 
// 访问方法
obj.function_name()
完整实例
以下实例创建来一个 Car 类,然后通过关键字 new 来创建一个对象并访问属性和方法:
TypeScript
classCar{engine:string; 
   
   constructor(engine:string){this.engine = engine}disp():void{console.log("函数中显示发动机型号  :   "+this.engine)}}varobj = newCar("XXSY1")console.log("读取发动机型号 :  "+obj.engine)obj.disp()
编译以上代码,得到以下 JavaScript 代码:
JavaScript
varCar = (function(){functionCar(engine){this.engine = engine;
    }Car.prototype.disp = function(){console.log("函数中显示发动机型号  :   " + this.engine);
    };
    returnCar;
}());
varobj = newCar("XXSY1");
console.log("读取发动机型号 :  " + obj.engine);
obj.disp();
输出结果为:
读取发动机型号 :  XXSY1
函数中显示发动机型号  :   XXSY1
类的继承
TypeScript 支持继承类,即我们可以在创建类的时候继承一个已存在的类,这个已存在的类称为父类,继承它的类称为子类。
类继承使用关键字 extends,子类除了不能继承父类的私有成员(方法和属性)和构造函数,其他的都可以继承。
TypeScript 一次只能继承一个类,不支持继承多个类,但 TypeScript 支持多重继承(A 继承 B,B 继承 C)。
语法格式如下:
class child_class_name extends parent_class_name
实例
类的继承:实例中创建了 Shape 类,Circle 类继承了 Shape 类,Circle 类可以直接使用 Area 属性:
TypeScript
classShape{Area:numberconstructor(a:number){this.Area = a}}classCircleextendsShape{disp():void{console.log("圆的面积:  "+this.Area)}}varobj = newCircle(223); 
obj.disp()
编译以上代码,得到以下 JavaScript 代码:
JavaScript
var__extends = (this && this.__extends) || (function(){varextendStatics = function(d, b){extendStatics = Object.setPrototypeOf ||
            ({__proto__: []}instanceofArray && function(d, b){d.__proto__ = b; }) ||
            function(d, b){for(varpinb)if(b.hasOwnProperty(p))d[p] = b[p]; };
        returnextendStatics(d, b);
    };
    returnfunction(d, b){extendStatics(d, b);
        function__(){this.constructor = d; }d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new__());
    };
})();
varShape = (function(){functionShape(a){this.Area = a;
    }returnShape;
}());
varCircle = (function(_super){__extends(Circle, _super);
    functionCircle(){return_super !== null && _super.apply(this, arguments) || this;
    }Circle.prototype.disp = function(){console.log("圆的面积:  " + this.Area);
    };
    returnCircle;
}(Shape));
varobj = newCircle(223);
obj.disp();
输出结果为:
圆的面积:  223
需要注意的是子类只能继承一个父类,TypeScript 不支持继承多个类,但支持多重继承,如下实例:
TypeScript
classRoot{str:string; 
}classChildextendsRoot{}classLeafextendsChild{}varobj = newLeaf(); 
obj.str ="hello"console.log(obj.str)
编译以上代码,得到以下 JavaScript 代码:
JavaScript
var__extends = (this && this.__extends) || (function(){varextendStatics = function(d, b){extendStatics = Object.setPrototypeOf ||
            ({__proto__: []}instanceofArray && function(d, b){d.__proto__ = b; }) ||
            function(d, b){for(varpinb)if(b.hasOwnProperty(p))d[p] = b[p]; };
        returnextendStatics(d, b);
    };
    returnfunction(d, b){extendStatics(d, b);
        function__(){this.constructor = d; }d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new__());
    };
})();
varRoot = (function(){functionRoot(){}returnRoot;
}());
varChild = (function(_super){__extends(Child, _super);
    functionChild(){return_super !== null && _super.apply(this, arguments) || this;
    }returnChild;
}(Root));
varLeaf = (function(_super){__extends(Leaf, _super);
    functionLeaf(){return_super !== null && _super.apply(this, arguments) || this;
    }returnLeaf;
}(Child)); varobj = newLeaf();
obj.str = "hello";
console.log(obj.str);
输出结果为:
hello
继承类的方法重写
类继承后,子类可以对父类的方法重新定义,这个过程称之为方法的重写。
其中 super 关键字是对父类的直接引用,该关键字可以引用父类的属性和方法。
TypeScript
classPrinterClass{doPrint():void{console.log("父类的 doPrint() 方法。")}}classStringPrinterextendsPrinterClass{doPrint():void{super.doPrint()console.log("子类的 doPrint()方法。")}}
编译以上代码,得到以下 JavaScript 代码:
JavaScript
varobj = newStringPrinter()obj.doPrint()var__extends = (this && this.__extends) || (function(){varextendStatics = function(d, b){extendStatics = Object.setPrototypeOf ||
            ({__proto__: []}instanceofArray && function(d, b){d.__proto__ = b; }) ||
            function(d, b){for(varpinb)if(b.hasOwnProperty(p))d[p] = b[p]; };
        returnextendStatics(d, b);
    };
    returnfunction(d, b){extendStatics(d, b);
        function__(){this.constructor = d; }d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new__());
    };
})();
varPrinterClass = (function(){functionPrinterClass(){}PrinterClass.prototype.doPrint = function(){console.log("父类的 doPrint() 方法。");
    };
    returnPrinterClass;
}());
varStringPrinter = (function(_super){__extends(StringPrinter, _super);
    functionStringPrinter(){return_super !== null && _super.apply(this, arguments) || this;
    }StringPrinter.prototype.doPrint = function(){_super.prototype.doPrint.call(this); console.log