// 定义一个简单的TypeScript接口
interface Person {
name: string;
age: number;
}
// 实现接口
const person: Person = {
name: 'Alice',
age: 30
};
// 使用泛型定义一个函数,该函数可以处理不同类型的数据
function identity<T>(arg: T): T {
return arg;
}
// 使用泛型定义一个类,用于存储不同类型的数据
class Box<T> {
private value: T;
constructor(value: T) {
this.value = value;
}
public getValue(): T {
return this.value;
}
}
// 使用泛型类创建一个String类型的Box实例
const stringBox = new Box<string>('Hello World');
// 使用泛型类创建一个Number类型的Box实例
const numberBox = new Box<number>(42);
// 使用类型别名定义一个新的类型
type StringOrNumber = string | number;
// 使用类型断言确保类型安全
const someValue: any = 'This is a string';
const stringValue = (<string>someValue).toUpperCase();
// 使用类型保护来检查类型并执行不同的操作
function isNumber(x: StringOrNumber): x is number {
return typeof x === 'number';
}
const a: StringOrNumber = 123;
if (isNumber(a)) {
console.log(a + 1); // 在类型保护之后,a被识别为number
} else {
console.log(a.toUpperCase()); // 在类型保护之后,a被识别为string
}
这段代码展示了TypeScript中的一些基本概念,包括接口、泛型、泛型类、类型别名、类型断言和类型保护。每一个概念都是TypeScript语言的核心特性,并且在实际开发中都有广泛的应用。通过学习这些最佳实践,开发者可以编写更加清晰、类型安全的代码。