1、类(class)
//属性可以使用public、private、protect修饰
class Person{
constructor() {
console.log("构造方法========");
}
public name;
public eat() {
console.log("正在吃==========");
}
}
var p1 = new Person();
p1.name = "pangzi";
p1.eat();
//类的继承
class student extends Person{
code: string;
//子类的构造方法必须调用父类构造方法
constructor(code:string) {
super();
this.code = code;
}
doWoerk(){
//使用super关键字调用父类方法
super.eat();
}
}
var stu = new student("023145");
2、泛型(generic)
class Person{
constructor() {
console.log("构造方法========");
}
public name;
public eat() {
console.log("正在吃==========");
}
}
var p1 = new Person();
p1.name = "pangzi";
p1.eat();
class Student extends Person{
code: string;
//子类的构造方法必须调用父类构造方法
constructor(code:string) {
super();
this.code = code;
}
}
var stu = new Student("023145");
//泛型
var students: Array<Person> = [];
students[0]=new Student("023145");
3、接口(interface)
interface IPerson{
name: string;
age: number;
}
class Person{
//使用接口来限制参数类型
constructor(public config:IPerson) {
}
}
var p1 = new Person({
name: "pangzi",
age:18
});
interface Animal{
eat();
}
class Sheep implements Animal{
eat() {
console.log("实现接口的class必须实现这个方法");
}
}
4、模块(module)
模块:类似java中的 导包。
一个文件就是一个模块,一个模块内部使用两个关键字export、import。
export:声明模块对外暴露什么
import:声明其他模块对这个模块提供什么
a.ts:
export var pro;
var pro1;
export function func() {
}
export function func1() {
}
export class Clazz {
}
class Clazz1 {
}
b.ts:
import {pro} from "./a";
console.log(pro);
5、注解(annotation)
注解在类上、方法上、属性上,声明加载这个类(方法、属性)时需要做什么事情
在这里插入代码片
6、类型定义文件(*.d.ts)
在TypeScript中使用类型定义文件,帮助开发者在TypeScript中使用已有的JS工具包,比如JQuery。