官术网_书友最值得收藏!

Type aliases

In simple terms, a type alias creates a new name for a type. To define a type alias, we use the type keyword, followed by the alias name, followed by the type that we want to alias.

We'll explore this with the following example:

  1. Let's create a type alias for the getTotal method in the OrderDetail interface we have been working with. Let's try this in the TypeScript playground:
type GetTotal = (discount: number) => number;

interface OrderDetail {
product: Product;
quantity: number;
getTotal: GetTotal;
}

Nothing changes with objects that implement this interface – it is purely a way we can structure our code. It arguably makes the code a little more readable.

  1. Type aliases can also define the shape of an object. We could use a type alias for our Product and OrderDetail types that we previously defined with an interface:
type Product = {
name: string;
unitPrice: number;
};

type OrderDetail = {
product: Product;
quantity: number;
getTotal: (discount: number) => number;
};
  1. We use these types in exactly the same way as we used our interface-based types:
const table: Product = {
name: "Table",
unitPrice: 500
};

const orderDetail: OrderDetail = {
product: table,
quantity: 1,
getTotal(discount: number): number {
const priceWithoutDiscount = this.product.unitPrice * this.quantity;
const discountAmount = priceWithoutDiscount * discount;
return priceWithoutDiscount - discountAmount;
}
};

So, type aliases seem very similar to interfaces. What is the difference between a type alias and an interface? The main difference is that type aliases can't be extended or implemented from like you can with interfaces. So, for a simple structure that doesn't require inheritance, should we use an interface or should we use a type alias? There isn't strong reasoning to prefer either approach. However, we should be consistent with whichever approach we choose to improve the readability of our code.

主站蜘蛛池模板: 乳山市| 南川市| 丰都县| 防城港市| 惠安县| 南涧| 洪江市| 武山县| 黎平县| 寻甸| 黄陵县| 藁城市| 阿荣旗| 宿松县| 衢州市| 宿松县| 莱阳市| 鹤峰县| 齐河县| 青冈县| 高雄市| 奎屯市| 德庆县| 全州县| 济宁市| 乳山市| 河东区| 镇远县| 祁东县| 彩票| 武胜县| 襄汾县| 清远市| 密山市| 清涧县| 安庆市| 麻栗坡县| 天等县| 资中县| 乐亭县| 泰顺县|