接口
我们就约束了tom的形状必须和接口Person一致。
定义的变量比接口少了一些属性是不允许的
多一些属性也是不允许的:
interface Person {
name: 那么多人破解通达信交易接口,string;
age: number;
}
let tom: Person = {
name: 'Tom',
age: 25,
gender: 'male'
};
都是会报错的
可选属性
interface Person {
name: 那么多人破解通达信交易接口,string;
age?: number;
}
let tom: Person = {
name: 'Tom'
};
// 可以有也可以没有
属性后加问好表示可选,可以有也可以没有这时还是不允许添加未定义的属性
有时候我们希望一个接口允许有任意的属性,可以使用如下方式:
interface Person {
name: string;
age?: number;
[propName: string]: any;
}
let tom: Person = {
name: 'Tom',
gender: 'male',
jj:'haoa'
};
一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它的类型的子集
interface Person {
name: string;
age?: number;
[propName: string]: string;
}
let tom: Person = {
name: 'Tom',
age: 25,
gender: 'male'
};
// 这个就会报错
上例中,任意属性的值允许是string,但是可选属性age的值却是number,number不是string的子属性,所以报错了。就是他范围必须大于原来那些定义的
只读属性
interface Person {
readonly id: number;
name: string;
age?: number;
[propName: string]: any;
}
let tom: Person = {
id: 89757,
name: 'Tom',
gender: 'male'
};
tom.id = 9527;
// index.ts(14,5): error TS2540: Cannot assign to 'id' because it is a constant or a read-only property
使用readonly定义的属性id初始化后,又被赋值了,所以报错了。
注意,只读的约束存在于第一次给对象赋值的时候,而不是第一次给只读属性赋值的时候
上例中,报错信息有两处,第一处是在对tom进行赋值的时候,没有给id赋值。第二处是在给toid赋值的时候,由于它是只读属性,所以报错了。
文章为作者独立观点,不代表股票交易接口观点