- Learn React with TypeScript 3
- Carl Rippon
- 326字
- 2021-06-10 19:16:39
Configuring rules
The rules that tslint uses when checking our code are configurable in a file called tslint.json. In order to explore some of the rules, we first need a TypeScript file:
- So, let's create a file called orderDetail.ts with the following content in Visual Studio Code:
export interface Product {
name: string;
unitPrice: number;
}
export class OrderDetail {
product: Product;
quantity: number;
getTotal(discount: number): number {
const priceWithoutDiscount = this.product.unitPrice * this.quantity;
const discountAmount = priceWithoutDiscount * discount;
return priceWithoutDiscount - discountAmount;
}
}
- Let's now create a tslint.json file. We define the rules we want to implement in a rules field. Let's add the following rule:
{
"rules": {
"member-access": true
}
}
- A full list of the rules can be found at: https://palantir.github.io/tslint/rules/. The member-access rule forces us to explicitly declare the access modifier for classes. We haven't explicitly defined the property and method access modifiers in the OrderDetail class because they are public by default. So, with our linting rule in place, Visual Studio Code will highlight the lack of access modifiers to us:
- As we put a public access modifier in front of the properties and method, the warnings go away:
export class OrderDetail {
public product: Product;
public quantity: number;
public getTotal(discount: number): number {
const priceWithoutDiscount = this.product.unitPrice * this.quantity;
const discountAmount = priceWithoutDiscount * discount;
return priceWithoutDiscount - discountAmount;
}
}
The member-access rule forces us to write more code – how can this be a good thing? The rule is useful if you're reading the code and don't know TypeScript well enough to understand that class members without access modifiers are public. So, it's great if our team consists of developers who don't know TypeScript that well yet, but not necessarily for an experienced team of TypeScript developers.
Lots of the tslint rules are like member-access – in some teams, they will work well and in others, they don't really add value. This is why rules are configurable!
推薦閱讀
- Web前端開發技術:HTML、CSS、JavaScript(第3版)
- 控糖控脂健康餐
- GitLab Repository Management
- Learn React with TypeScript 3
- INSTANT Passbook App Development for iOS How-to
- 青少年信息學競賽
- Terraform:多云、混合云環境下實現基礎設施即代碼(第2版)
- Apache Camel Developer's Cookbook
- 零基礎學SQL(升級版)
- 深入淺出 HTTPS:從原理到實戰
- Java設計模式深入研究
- HTML5 Canvas核心技術:圖形、動畫與游戲開發
- Practical Linux Security Cookbook
- Getting Started with Backbone Marionette
- R語言編程:基于tidyverse