对象的类型
在 typescript 中,我们定义对象的方式要用关键字 interface(接口),我的理解是使用 interface 来定义一种约束,让数据的结构满足约束的格式。定义方式如下:
1 2 3 4 5 6 7 8 9 10
|
interface Person { b: string; a: string; } const person: Person = { a: "213", };
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| interface A { name: string; } interface A { age: number; } var x: A = { name: "xx", age: 20 };
interface A { name: string; }
interface B extends A { age: number; }
let obj: B = { age: 18, name: "string", };
|
可选属性 使用?
操作符
1 2 3 4 5 6 7 8 9 10
|
interface Person { b?: string; a: string; }
const person: Person = { a: "213", };
|
任意属性 [propName: string]
需要注意的是,一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它的类型的子集:
1 2 3 4 5 6 7 8 9 10 11 12 13
|
interface Person { b?: string; a: string; [propName: string]: any; }
const person: Person = { a: "213", c: "123", };
|
只读属性 readonly
readonly 只读属性是不允许被赋值的只能读取
1 2 3 4 5 6 7 8 9 10 11 12 13
|
interface Person { b?: string, readonly a: string, [propName: string]: any; }
const person: Person = { a: "213", c: "123" } person.a = 123
|
添加函数
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| interface Person { b?: string, readonly a: string, [propName: string]: any; cb():void }
const person: Person = { a: "213", c: "123", cb:()=>{ console.log(123) } }
|
数组的类型
- 类型[ ]
1 2 3 4 5 6 7 8 9 10
| let arr: number[] = [123];
let arr: number[] = [1, 2, 3, "1"];
let arr: number[] = [1, 2, 3]; arr.unshift("1"); var arr: number[] = [1, 2, 3]; var arr2: string[] = ["1", "2"]; var arr3: any[] = [1, "2", true];
|
数组泛型
规则 Array<类型>
1
| let arr: Array<number> = [1, 2, 3, 4, 5];
|
用接口表示数组
一般用来描述类数组
1 2 3 4 5
| interface NumberArray { [index: number]: number; } let fibonacci: NumberArray = [1, 1, 2, 3, 5];
|
函数的类型
1 2 3 4 5
| const fn = (name: string, age: number): string => { return name + age; }; fn("张三", 18);
|
函数的可选参数?
1 2 3 4
| const fn = (name: string = "我是默认值"): string => { return name; }; fn();
|
函数参数的默认值
1 2 3 4
| const fn = (name: string = "我是默认值"): string => { return name; }; fn();
|
接口定义函数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| interface Add { (num: number, num2: number): number; }
const fn: Add = (num: number, num2: number): number => { return num + num2; }; fn(5, 5);
interface User { name: string; age: number; } function getUserInfo(user: User): User { return user; }
|
定义剩余参数
1 2 3 4 5 6 7 8
| const fn = (array: number[], ...items: any[]): any[] => { console.log(array, items); return items; };
let a: number[] = [1, 2, 3];
fn(a, "4", "5", "6");
|
函数重载
重载是方法名字相同,而参数不同,返回类型可以相同也可以不同。
如果参数类型不同,则参数类型应设置为 any。
参数数量不同你可以将不同的参数设置为可选。
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| function fn(params: number): void
function fn(params: string, params2: number): void
function fn(params: any, params2?: any): void {
console.log(params)
console.log(params2)
} fn(123)
fn('123',456)
|