- Expert Angular
- Mathieu Nayrolles Rajesh Gunasundaram Sridhar Rao
- 300字
- 2021-07-15 17:05:31
Interfaces
An interface is an abstract type that defines the behavior of a class. An interface is a contract that abstracts the implementation. An interface provides a type definition for an object that can be exchanged between clients. This enables the client to only exchange an object that is complied with the interface type definition. Otherwise, we get a compile time error.
In TypeScript, interfaces define contracts for an object within your code and the code outside your project. Let's see how to use TypeScript with an example:
function addCustomer(customerObj: {name: string}) { console.log(customerObj.name); } var customer = {id: 101, name: "Rajesh Gunasundaram"}; addCustomer(customer);
The type checker verifies the addCustomer method call and examines its parameter. addCustomer expects an object with the name property of the string type. But the client that calls addCustomer is passed an object with two parameters, id and name, respectively.
However, the compiler does not check the id property as it is not available in the parameter type of the addCustomer method. It only matters for the compiler that the required properties are present.
Let's rewrite the method applying interface as a parameter type as follows:
interface Customer { name: string; } function addCustomer(customerObj: Customer) { console.log(customerObj.name); }
var customer = {id: 101, name: "Rajesh Gunasundaram"}; addCustomer(customer);
Here, we declared the Customer interface with the name parameter, and we modified the addCustomer signature to accept the parameter of the type Customer interface. The remaining statements are same as in the previous code snippet. The compiler only checks for the shape of the object as TypeScript implements the structural type system. It will not check whether the object we are passing implements the Customer interface. It only looks for the name property of the string type in the parameter and then allows it, if it's present.
- Getting Started with Citrix XenApp? 7.6
- Building Modern Web Applications Using Angular
- Building a RESTful Web Service with Spring
- JavaScript 網頁編程從入門到精通 (清華社"視頻大講堂"大系·網絡開發視頻大講堂)
- 算法大爆炸:面試通關步步為營
- 深入RabbitMQ
- C語言程序設計教程
- 微服務架構深度解析:原理、實踐與進階
- Learning PHP 7
- Mastering ArcGIS Enterprise Administration
- 案例式C語言程序設計實驗指導
- 面向對象分析與設計(第3版)
- Learning Gerrit Code Review
- 走近SDN/NFV
- Cocos2D Game Development Essentials