一个接口是一个TypeScript工件,它不是ECMAScript的一部分。 接口是一种用于相对于参数及其类型定义函数上的契约的方式。 除了函数,接口也可以与类一起使用以定义自定义类型。
接口是一个抽象类型,它不像类一样包含任何代码。 它仅定义API的“签名”或形状。 在代码转换期间,interface 不会生成任何代码,它仅在开发期间被Typescript用于类型检查。
下面是描述函数API的接口的示例:
interface Callback {
(error: Error, data: any): void;
}
function callServer(callback: Callback) {
callback(null, 'hi');
}
callServer((error, data) => console.log(data)); // 'hi'
callServer('hi'); // tsc error
有时JavaScript函数可以接受多个类型以及不同的参数,也就是说,它们可以有不同的调用签名。接口可以用来指定。
interface PrintOutput {
(message: string): void; // common case
(message: string[]): void; // less common case
}
let printOut: PrintOutput = (message) => {
if (Array.isArray(message)) {
console.log(message.join(', '));
} else {
console.log(message);
}
}
printOut('hello'); // 'hello'
printOut(['hi', 'bye']); // 'hi, bye'
下面是一个描述对象字面量的接口的示例:
interface Action {
type: string;
}
let a: Action = {
type: 'literal'
}