- Learn React with TypeScript 3
- Carl Rippon
- 295字
- 2021-06-10 19:16:33
Enumerations
Enumerations allow us to declare a meaningful set of friendly names that a variable can be set to. We use the enum keyword, followed by the name we want to give to it, followed by the possible values in curly braces.
Here's an example:
- Let's declare an enum for order statuses in the TypeScript playground:
enum OrderStatus {
Paid,
Shipped,
Completed,
Cancelled
}
- If we look at the transpiled JavaScript, we see that it looks very different:
var OrderStatus;
(function (OrderStatus) {
OrderStatus[OrderStatus["Paid"] = 1] = "Paid";
OrderStatus[OrderStatus["Shipped"] = 2] = "Shipped";
OrderStatus[OrderStatus["Completed"] = 3] = "Completed";
OrderStatus[OrderStatus["Cancelled"] = 4] = "Cancelled";
})(OrderStatus || (OrderStatus = {}));
This is because enumerations don't exist in JavaScript, so the TypeScript compiler is transpiling the code into something that does exist.
- Let's declare a status variable, setting the value to the shipped status:
let status = OrderStatus.Shipped;
Notice how we get nice IntelliSense when typing the value:
- By default, the numerical values start from 0 and increment. However, the starting value can be explicitly declared in the enum, as in the following example, where we set Paid to 1:
enum OrderStatus {
Paid = 1,
Shipped,
Completed,
Cancelled
}
- Let's set our status variable to the shipped status and log this to the console:
let status = OrderStatus.Shipped;
console.log(status);
If we run the program, we should see 2 output in the console:
- In addition, all the values can be explicitly declared, as in the following example:
enum OrderStatus {
Paid = 1,
Shipped = 2,
Completed = 3,
Cancelled = 0
}
Enumerations are great for data such as a status that is stored as a specific set of integers but actually has some business meaning. They make our code more readable and less prone to error.
推薦閱讀
- TypeScript Essentials
- Mobile Web Performance Optimization
- CMDB分步構建指南
- 程序設計與實踐(VB.NET)
- QGIS:Becoming a GIS Power User
- Learn React with TypeScript 3
- 零基礎輕松學SQL Server 2016
- HTML+CSS+JavaScript編程入門指南(全2冊)
- Orchestrating Docker
- QGIS 2 Cookbook
- WildFly Cookbook
- Learning C++ by Creating Games with UE4
- Android技術內幕(系統卷)
- 高性能MVVM框架的設計與實現:San
- Lync Server Cookbook