- Learn React with TypeScript 3
- Carl Rippon
- 320字
- 2021-06-10 19:16:33
Objects
The object type is shared with JavaScript and represents a non-primitive type. Objects can contain typed properties to hold bits of information.
Let's work through an example:
- Let's enter the following code into the TypeScript playground, which creates an object with several properties of information:
const customer = {
name: "Lamps Ltd",
turnover: 2000134,
active: true
};
If we hover over name, turnover, and active, we'll see that TypeScript has smartly inferred the types to be string, number, and boolean respectively.
- If we hover over the customer variable name, we see something interesting:
- Rather than the type being object, it is a specific type with name, turnover, and active properties. On the next line, let's set the turnover property to some other value:
customer.turnover = 500000;
As we type the turnover property, IntelliSense provides the properties that are available on the object:
- This line of code is perfectly fine, so we don't get any complaints from the compiler. If we set the turnover to a value that has an incorrect type, we'll be warned as we would expect:
- Now let's set a property on customer that doesn't exist yet:
customer.profit = 10000;
We'll see that TypeScript complains:
This makes sense if we think about it. We've declared customer with name, turnover, and active properties, so setting a profit property should cause an error. If we wanted a profit property, we should have declared it in the original declaration.
In summary, the object type is flexible because we get to define any properties we require, but TypeScript will narrow down the type to prevent us incorrectly typing a property name.
- JavaScript前端開發模塊化教程
- Hands-On JavaScript High Performance
- 軟件工程
- EPLAN實戰設計
- 打開Go語言之門:入門、實戰與進階
- Orleans:構建高性能分布式Actor服務
- Django 5企業級Web應用開發實戰(視頻教學版)
- 3D Printing Designs:Octopus Pencil Holder
- Mastering ASP.NET Web API
- Android 5從入門到精通
- Internet of Things with Arduino Cookbook
- ServiceDesk Plus 8.x Essentials
- Java Web程序員面試筆試寶典
- 51單片機C語言程序設計經典實例(第3版)
- Building RESTful Web Services with PHP 7