{% endif %}
diff --git a/src/_includes/layouts/post.html b/src/_includes/layouts/post.html
index c9a5394799..ea5a4e3089 100644
--- a/src/_includes/layouts/post.html
+++ b/src/_includes/layouts/post.html
@@ -45,7 +45,9 @@
title: all_authors[author].title,
handle: all_authors[author].username,
github: all_authors[author].github_username,
+ bluesky: all_authors[author].bluesky_url,
twitter: all_authors[author].twitter_username,
+ mastodon: all_authors[author].mastodon_url,
bio: all_authors[author].bio
}) }}
{% endfor %}
diff --git a/src/_includes/partials/author_bios/joshuakgoldberg.md b/src/_includes/partials/author_bios/joshuakgoldberg.md
new file mode 100644
index 0000000000..1980e0cfc8
--- /dev/null
+++ b/src/_includes/partials/author_bios/joshuakgoldberg.md
@@ -0,0 +1 @@
+I'm involved with projects in the TypeScript ecosystem such as typescript-eslint, and wrote *Learning TypeScript* (O'Reilly).
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
new file mode 100644
index 0000000000..ff66c02e45
--- /dev/null
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -0,0 +1,248 @@
+---
+layout: post
+title: "Differences between linting and type checking"
+teaser: "Linters such as ESLint and type checkers such as TypeScript catch different areas of code defects — and are best used in conjunction with each other."
+authors:
+ - joshuakgoldberg
+categories:
+ - Storytime
+tags:
+ - Linting
+---
+
+Linters and type checkers are two kinds of tools that both analyze code and report on detected issues.
+They may seem similar at first.
+However, the two kinds of tools detect very different issues and are useful in different ways.
+
+## Definitions
+
+*"Static analysis"* is the term for tooling that checks code for issues without running it.
+There are three forms of static analysis commonly used in web development projects today:
+
+1. **Formatters**: only print your code quickly, without worrying about logic
+2. **Linters**: execute individually configurable checks known as "lint rules"
+3. **Type checkers**: collect all files into a full understanding of the project
+
+We'll focus in this blog post on *linters*, namely ESLint, and *type checkers*, namely [TypeScript](https://typescriptlang.org).
+ESLint and TypeScript are often used together to detect defects in code.
+
+## Differences in Purpose
+
+Type checkers make sure the *intent* behind values in code matches the *usage* of those values.
+They check that code is "type-safe": meaning values are used according to the ways their types describe as being allowed.
+
+Type checkers do not attempt to look for defects that are only likely, rather than certain.
+Nor do type checkers enforce subjective opinions that might change between projects.
+That means TypeScript does not attempt to enforce general best practices — only that values are used in type-safe ways.
+TypeScript won't detect likely mistakes that work within those types.
+
+Linters, on the other hand, primarily target *likely* defects and can also be used to enforce subjective opinions.
+ESLint and other linters catch issues that are technically type-safe but are potential sources of bugs.
+Many developers rely on linters to make sure their code follow framework and language best practices.
+
+For example, developers sometimes leave out the `break` or `return` at the end of a `switch` statement's `case`.
+Doing so is type-safe and permitted by JavaScript and TypeScript.
+In practice, this is almost always a mistake that allows the next `case` statement to run accidentally.
+ESLint's [`no-fallthrough`](https://eslint.org/docs/latest/rules/no-fallthrough) can catch that likely mistake:
+
+```ts
+function logFruit(value: "apple" | "banana" | "cherry") {
+ switch (value) {
+ case "apple":
+ console.log("🍏");
+ break;
+
+ case "banana":
+ console.log("🍌");
+
+ // eslint(no-fallthrough):
+ // Expected a 'break' statement before 'case'.
+
+ case "cherry":
+ console.log("🍒");
+ break;
+ }
+}
+
+// Logs:
+// 🍌
+// 🍒
+logFruit("banana");
+```
+
+Another way of looking at the differences between linters and type checkers is that type checkers enforce what you *can* do, whereas linters enforce what you *should* do.
+
+### Granular Extensibility
+
+Another difference between linters and type checkers is how flexibly their areas of responsibility can be configured.
+
+Type checkers are generally configured with a set list of compiler options on a project level.
+TypeScript's [`tsconfig.json` ("TSConfig") files](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allow for compiler options that change type checking for all files in the project.
+Those compiler options are set by TypeScript and generally change large swathes of type checking behavior.
+
+Linters, on the other hand, run with a configurable set of lint rules.
+Each lint rule can be granularly configured.
+If you don't like a particular lint rule, you can always turn it off for a line, set of files, or your entire project.
+
+Linters can also can be augmented by **plugins** that add new lint rules.
+Plugin-specific lint rules extend the breadth of code checks that linter configurations can pick and choose from.
+
+For example, this ESLint configuration enables the recommended rules from [`eslint-plugin-jsx-a11y`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y), a plugin that adds checks for accessibility in JSX libraries such as Solid.js and React:
+
+```js title="eslint.config.js"
+import js from "@eslint/js";
+import jsxA11y from "eslint-plugin-jsx-a11y"
+
+export default [
+ js.configs.recommended,
+ jsxA11y.flatConfigs.recommended,
+ // ...
+];
+```
+
+A project using the JSX accessibility rules would then be told if they render a native `` tag without descriptive text per [`jsx-a11y/alt-text`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/blob/main/docs/rules/alt-text.md):
+
+```tsx
+const MyComponent = () => ;
+// ~~~~~~~~~~~~~~~~~~~~~~~~~
+// eslint(jsx-a11y/alt-text):
+// img elements must have an alt prop, either with meaningful text, or an empty string for decorative images.
+```
+
+By adding in rules from plugins, linter configurations can be tailored to the specific best practices and common issues to the frameworks a project is built with.
+
+### Areas of Overlap
+
+Linters and type checkers operate differently and specialize in different areas of code defects.
+Some code defects straddle the line between "best practices" and "type safety", and so can be caught by both linting and type checking.
+There are some core rules in that are superseded by TypeScript's type checking.
+
+To make the most of both tools, we recommend:
+
+* In your ESLint configuration file, use the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration), at least the [`tseslint.configs.recommended` configuration from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting), and any community plugins relevant to your project's libraries and frameworks
+* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict)
+
+typescript-eslint's recommended preset configs disable core ESLint rules that are not helpful with TypeScript.
+The configs leave on any core ESLint rules that are useful alongside type checking.
+
+#### Unused Locals and Parameters
+
+The only TypeScript compiler options we recommend keeping off when using linting are those that enable checking for unused variables:
+
+* [`noUnusedLocals`](https://www.typescriptlang.org/tsconfig/#noUnusedLocals): which reports on unused declared local variables
+* [`noUnusedParameters`](https://www.typescriptlang.org/tsconfig/#noUnusedParameters): which reports on unused function parameters
+
+Those compiler options are useful when not using a linter.
+However, they aren't configurable the way lint rules are, and so can't be configured to higher or lower strictness levels per a project's preferences.
+The compiler options are hardcoded to always ignore any variable whose name begins with `_`.
+
+As an example, the following `registerCallback` function declares two parameters for its callbacks -`id` and `message`- but the developer using it only needed `message`.
+TypeScript's `noUnusedParameters` compiler option would not flag the unused parameter `_`:
+
+```ts
+type Callback = (id: string, message: string) => void;
+
+declare function registerCallback(callback: Callback): void;
+
+// We only want to log message, not id
+registerCallback((_, message) => console.log(message));
+```
+
+Unused variables in JavaScript can also be caught by ESLint's [`no-unused-vars`](https://eslint.org/docs/latest/rules/no-unused-vars) rule; when in TypeScript code, the [`@typescript-eslint/no-unused-vars`](https://typescript-eslint.io/rules/no-unused-vars) is preferred instead.
+The lint rules by default also ignore variables whose name begins with `_`.
+They additionally ignore parameters that come before any parameter that is itself used.
+
+Some projects prefer to never allow unused parameters regardless of name or position.
+That stricter preferences helps prevent API designs that lead developers to creating many unused parameters.
+
+A more strict ESLint configuration would be able to report on the `_` parameter:
+
+```ts
+/* eslint @typescript-eslint/no-unused-vars: ["error", { "args": "all", "argsIgnorePattern": "" }] */
+
+type Callback = (id: string, message: string) => void;
+
+declare function registerCallback(callback: Callback): void;
+
+// We only want to log message, not id
+registerCallback((_, message) => console.log(message));
+// ~
+// eslint(@typescript-eslint/no-unused-vars):
+// '_' is declared but never used.
+```
+
+That extra level of configurability provided by the `no-unused-vars` rules can allow them to act as more granularly configurable versions of their equivalent TypeScript compiler options.
+
+> đź’ˇ See [`no-unused-binary-expressions`: From code review nit to ecosystem improvements](/blog/2024/10/code-review-nit-to-ecosystem-improvements) for more areas of code checking with partial overlap between linting and type checking.
+
+## Is a Linter Still Useful With a Type Checker?
+
+**Yes.**
+
+If you are using TypeScript, it is still very useful to use ESLint.
+In fact, linters and type checkers are at their most powerful when used in conjunction with each other.
+
+### Linters, With Type Information
+
+Traditional lint rules run on a single file at a time and have no knowledge of other files in the project.
+They can't make decisions on files based on contents of other files.
+
+However, if your project is set up using TypeScript, you can opt into "type checked" lint rules: rules that can pull in type information.
+In doing so, type checked lint rules can make decisions based on other files.
+
+For example, [`@typescript-eslint/no-for-in-array`](https://typescript-eslint.io/rules/no-for-in-array) is able to detect `for...in` loops over values that are array types, even if the values come from other files.
+TypeScript would not report a type error for a `for...in` loop over an array because doing so is technically type-safe and might be what a developer intended.
+A linter, however, could be configured to notice that the developer probably made a mistake and meant to use a `for...of` loop instead:
+
+```ts
+// declare function getArrayOfNames(): string[];
+import { getArrayOfNames } from "./my-names";
+
+for (const name in getArrayOfNames()) {
+ // eslint(@typescript-eslint/no-for-in-array):
+ // For-in loops over arrays skips holes, returns indices as strings,
+ // and may visit the prototype chain or other enumerable properties.
+ // Use a more robust iteration method such as for-of or array.forEach instead.
+ console.log(name);
+}
+```
+
+Augmenting the linter with information from the type checker makes for a more powerful set of lint rules.
+See [Typed Linting: The Most Powerful TypeScript Linting Ever](https://typescript-eslint.io/blog/typed-linting) for more details on typed linting with typescript-eslint.
+
+### Type Checkers, With Linting
+
+TypeScript adds extra complexity to JavaScript.
+That complexity is often worth it, but any added complexity brings with it the potential for misuse.
+Linters are useful for stopping developers from making TypeScript-specific blunders in code.
+
+For example, TypeScript's `{}` ("empty object") type is often misused by developers new to TypeScript.
+It visually looks like it should mean any `object`, but actually means any non-`null`, non-`undefined` value --- including primitives such as `number`s and `string`s.
+[`@typescript-eslint/no-empty-object-type`](https://typescript-eslint.io/rules/no-empty-object-type) catches uses of the `{}` type that likely meant `object` or `unknown` instead:
+
+```ts
+export function logObjectEntries(value: {}) {
+ // ~~
+ // eslint(@typescript-eslint/no-empty-object-type):
+ // The `{}` ("empty object") type allows any non-nullish value, including literals like `0` and `""`.
+ // - If that's what you want, disable this lint rule with an inline comment or configure the 'allowObjectTypes' rule option.
+ // - If you want a type meaning "any object", you probably want `object` instead.
+ // - If you want a type meaning "any value", you probably want `unknown` instead.
+ console.log(Object.entries(value));
+}
+
+logObjectEntries(0); // No type error!
+```
+
+Enforcing language-specific best practices with a linter helps developers learn about and correctly use type checkers such as TypeScript.
+
+## Conclusion
+
+Linters such as ESLint and type checkers such as TypeScript are both valuable assets for developers.
+The two catch different areas of code defects and come with different philosophies around configurability and extensibility.
+
+* Type checkers check that code is "type-safe": enforcing what you *can* write
+* Linters check that code adheres to best practices and is consistent: enforcing what you *should* write
+
+Put together, the two tools help projects write code with fewer bugs and more consistency.
+We recommend that any project that uses TypeScript additionally uses ESLint.
diff --git a/src/content/pages/team.html b/src/content/pages/team.html
index a16c4c27c3..335f6cda14 100644
--- a/src/content/pages/team.html
+++ b/src/content/pages/team.html
@@ -29,10 +29,10 @@
{{ site.team_page.tsc.title }}
{% set itemName = item.name %}
{% set itemHandle = item.username %}
-
{% set itemBio = item.bio | safe %}
{% set itemWebsite = item.website %}
{% set itemGitHub = item.github_username %}
+ {% set itemBluesky = item.bluesky_url %}
{% set itemTwitter = item.twitter_username %}
{% set itemMastodon = item.mastodon_url %}
@@ -44,6 +44,7 @@
{% set itemName = item.name %}
{% set itemHandle = item.username %}
+
{% set itemBio = item.bio | safe %}
{% set itemWebsite = item.website %}
{% set itemGitHub = item.github_username %}
- {% set itemBluesky = item.bluesky_url %}
{% set itemTwitter = item.twitter_username %}
{% set itemMastodon = item.mastodon_url %}
@@ -212,7 +208,6 @@
{{ site.team_page.support_team.title }}
handleURL: itemHandleURL,
bio: itemBio,
website: itemWebsite,
- bluesky: itemBluesky,
github: itemGitHub,
twitter: itemTwitter,
mastodon: itemMastodon
From 49076ee1aaac383319e36d9c3ef4158a2f3e9edc Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Josh=20Goldberg=20=E2=9C=A8?=
Date: Fri, 6 Dec 2024 09:06:21 -0500
Subject: [PATCH 03/26] Apply suggestions from code review
Co-authored-by: Nicholas C. Zakas
Co-authored-by: Amaresh S M
---
...ences-between-linting-and-type-checking.md | 22 +++++++++----------
1 file changed, 11 insertions(+), 11 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index ff66c02e45..2e86f15aaf 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -14,9 +14,9 @@ Linters and type checkers are two kinds of tools that both analyze code and repo
They may seem similar at first.
However, the two kinds of tools detect very different issues and are useful in different ways.
-## Definitions
+## What is static analysis?
-*"Static analysis"* is the term for tooling that checks code for issues without running it.
+*Static analysis* is the inspection of source code without executing it. This differs from *dynamic analysis*, in which source code is inspected while it is executed. As such, dynamic analysis brings with it the inherent danger of executing malicious code or creating side effects while static analysis is safe to execute regardless of the source code.
There are three forms of static analysis commonly used in web development projects today:
1. **Formatters**: only print your code quickly, without worrying about logic
@@ -26,19 +26,19 @@ There are three forms of static analysis commonly used in web development projec
We'll focus in this blog post on *linters*, namely ESLint, and *type checkers*, namely [TypeScript](https://typescriptlang.org).
ESLint and TypeScript are often used together to detect defects in code.
-## Differences in Purpose
+## Digging deeper into linting vs. type checking
Type checkers make sure the *intent* behind values in code matches the *usage* of those values.
-They check that code is "type-safe": meaning values are used according to the ways their types describe as being allowed.
+They check that code is "type-safe": values are used according to how their types are described as being allowed.
Type checkers do not attempt to look for defects that are only likely, rather than certain.
Nor do type checkers enforce subjective opinions that might change between projects.
That means TypeScript does not attempt to enforce general best practices — only that values are used in type-safe ways.
TypeScript won't detect likely mistakes that work within those types.
-Linters, on the other hand, primarily target *likely* defects and can also be used to enforce subjective opinions.
-ESLint and other linters catch issues that are technically type-safe but are potential sources of bugs.
-Many developers rely on linters to make sure their code follow framework and language best practices.
+Linters, on the other hand, primarily target likely defects and can also be used to enforce subjective opinions.
+ESLint and other linters catch issues that are may or may not be type-safe but are potential sources of bugs.
+Many developers rely on linters to make sure their code follows framework and language best practices.
For example, developers sometimes leave out the `break` or `return` at the end of a `switch` statement's `case`.
Doing so is type-safe and permitted by JavaScript and TypeScript.
@@ -84,7 +84,7 @@ Linters, on the other hand, run with a configurable set of lint rules.
Each lint rule can be granularly configured.
If you don't like a particular lint rule, you can always turn it off for a line, set of files, or your entire project.
-Linters can also can be augmented by **plugins** that add new lint rules.
+Linters can also be augmented by **plugins** that add new lint rules.
Plugin-specific lint rules extend the breadth of code checks that linter configurations can pick and choose from.
For example, this ESLint configuration enables the recommended rules from [`eslint-plugin-jsx-a11y`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y), a plugin that adds checks for accessibility in JSX libraries such as Solid.js and React:
@@ -115,7 +115,7 @@ By adding in rules from plugins, linter configurations can be tailored to the sp
Linters and type checkers operate differently and specialize in different areas of code defects.
Some code defects straddle the line between "best practices" and "type safety", and so can be caught by both linting and type checking.
-There are some core rules in that are superseded by TypeScript's type checking.
+There are some core rules that are superseded by TypeScript's type checking.
To make the most of both tools, we recommend:
@@ -153,7 +153,7 @@ The lint rules by default also ignore variables whose name begins with `_`.
They additionally ignore parameters that come before any parameter that is itself used.
Some projects prefer to never allow unused parameters regardless of name or position.
-That stricter preferences helps prevent API designs that lead developers to creating many unused parameters.
+These stricter preferences help prevent API designs that lead developers to create many unused parameters.
A more strict ESLint configuration would be able to report on the `_` parameter:
@@ -185,7 +185,7 @@ In fact, linters and type checkers are at their most powerful when used in conju
### Linters, With Type Information
Traditional lint rules run on a single file at a time and have no knowledge of other files in the project.
-They can't make decisions on files based on contents of other files.
+They can't make decisions on files based on the contents of other files.
However, if your project is set up using TypeScript, you can opt into "type checked" lint rules: rules that can pull in type information.
In doing so, type checked lint rules can make decisions based on other files.
From ad13f710d7ba760157937656ae8d5d5f9e78797b Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Fri, 6 Dec 2024 09:44:30 -0500
Subject: [PATCH 04/26] Clean up per nzakas review
---
...ences-between-linting-and-type-checking.md | 39 +++++++++++++++----
1 file changed, 31 insertions(+), 8 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 2e86f15aaf..2378fe3353 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -10,20 +10,29 @@ tags:
- Linting
---
+If you're a JavaScript developer today, you're probably using ESLint and/or TypeScript to assist development.
+Those two tools are common examples of their kind of tooling: ESLint is a common *linter*, whereas TypeScript is a common *type checker*.
+
Linters and type checkers are two kinds of tools that both analyze code and report on detected issues.
They may seem similar at first.
+They both fall under the category of *static analysis*.
However, the two kinds of tools detect very different issues and are useful in different ways.
## What is static analysis?
-*Static analysis* is the inspection of source code without executing it. This differs from *dynamic analysis*, in which source code is inspected while it is executed. As such, dynamic analysis brings with it the inherent danger of executing malicious code or creating side effects while static analysis is safe to execute regardless of the source code.
-There are three forms of static analysis commonly used in web development projects today:
+Static analysis is the inspection of source code without executing it.
+This differs from *dynamic analysis*, in which source code is inspected while it is executed.
+As such, dynamic analysis brings with it the inherent danger of executing malicious code or creating side effects while static analysis is safe to execute regardless of the source code.
-1. **Formatters**: only print your code quickly, without worrying about logic
-2. **Linters**: execute individually configurable checks known as "lint rules"
-3. **Type checkers**: collect all files into a full understanding of the project
+Static analysis can be immensely helpful for improving code readability, reliability, and overall quality.
+Many developers rely on static analysis to enforce consistent code formatting and style, to ensure code is well-documented, and to catch likely bugs.
+Because static analysis runs on source code, it can suggest improvements in editors, as code is written.
We'll focus in this blog post on *linters*, namely ESLint, and *type checkers*, namely [TypeScript](https://typescriptlang.org).
+
+* **ESLint**: executes individually configurable checks known as "lint rules"
+* **TypeScript**: collects all files into a full understanding of the project
+
ESLint and TypeScript are often used together to detect defects in code.
## Digging deeper into linting vs. type checking
@@ -31,7 +40,21 @@ ESLint and TypeScript are often used together to detect defects in code.
Type checkers make sure the *intent* behind values in code matches the *usage* of those values.
They check that code is "type-safe": values are used according to how their types are described as being allowed.
-Type checkers do not attempt to look for defects that are only likely, rather than certain.
+For example, TypeScript would report a type error on the following `logUppercase(9001)` call, because `logUppercase` is declared as receiving a `string` rather than a `number`:
+
+```ts
+function logUppercase(text: string) {
+ console.log(text.toUpperCase());
+}
+
+logUppercase(9001);
+```
+
+Compiled languages such as Java and Rust perform type checking as part of their compilation step.
+Because JavaScript is an interpreted language, TypeScript is run separately.
+
+Type checkers generally do not attempt to look for defects that are only likely to occur.
+Type checkers generally only look for defects that are certainly wrong.
Nor do type checkers enforce subjective opinions that might change between projects.
That means TypeScript does not attempt to enforce general best practices — only that values are used in type-safe ways.
TypeScript won't detect likely mistakes that work within those types.
@@ -74,9 +97,9 @@ Another way of looking at the differences between linters and type checkers is t
### Granular Extensibility
-Another difference between linters and type checkers is how flexibly their areas of responsibility can be configured.
+Another difference between ESLint and TypeScript is how flexibly their areas of responsibility can be configured.
-Type checkers are generally configured with a set list of compiler options on a project level.
+TypeScript is configured by a set list of compiler options on a project level.
TypeScript's [`tsconfig.json` ("TSConfig") files](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allow for compiler options that change type checking for all files in the project.
Those compiler options are set by TypeScript and generally change large swathes of type checking behavior.
From 62ca3490183011bc821962ed3ea0e703d622c2bb Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Fri, 6 Dec 2024 09:45:57 -0500
Subject: [PATCH 05/26] Add ~~~~ for TS
---
.../2024-12-04-differences-between-linting-and-type-checking.md | 2 ++
1 file changed, 2 insertions(+)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 2378fe3353..08f986ab00 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -48,6 +48,8 @@ function logUppercase(text: string) {
}
logUppercase(9001);
+// ~~~~
+// Argument of type 'number' is not assignable to parameter of type 'string'.
```
Compiled languages such as Java and Rust perform type checking as part of their compilation step.
From 822514ddbc6e5237650e29a983072cd148542029 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Fri, 6 Dec 2024 10:09:23 -0500
Subject: [PATCH 06/26] Clarify focus as on ESLint and TypeScript
---
...ences-between-linting-and-type-checking.md | 46 ++++++++++---------
1 file changed, 25 insertions(+), 21 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 08f986ab00..177e0c9213 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -28,12 +28,14 @@ Static analysis can be immensely helpful for improving code readability, reliabi
Many developers rely on static analysis to enforce consistent code formatting and style, to ensure code is well-documented, and to catch likely bugs.
Because static analysis runs on source code, it can suggest improvements in editors, as code is written.
-We'll focus in this blog post on *linters*, namely ESLint, and *type checkers*, namely [TypeScript](https://typescriptlang.org).
+We'll focus in this blog post on ESLint and TypeScript:
* **ESLint**: executes individually configurable checks known as "lint rules"
* **TypeScript**: collects all files into a full understanding of the project
-ESLint and TypeScript are often used together to detect defects in code.
+ESLint and TypeScript use some of the same forms of analysis to detect defects in code.
+They both analyze how scopes and variables are created and used in code, and can catch issues such as referencing a variable that doesn't exist.
+We'll explore the different ways the two use information from analyzing your code.
## Digging deeper into linting vs. type checking
@@ -56,9 +58,10 @@ Compiled languages such as Java and Rust perform type checking as part of their
Because JavaScript is an interpreted language, TypeScript is run separately.
Type checkers generally do not attempt to look for defects that are only likely to occur.
-Type checkers generally only look for defects that are certainly wrong.
+They generally only look for uses of code that are certainly wrong.
+
Nor do type checkers enforce subjective opinions that might change between projects.
-That means TypeScript does not attempt to enforce general best practices — only that values are used in type-safe ways.
+TypeScript does not attempt to enforce general best practices — only that values are used in type-safe ways.
TypeScript won't detect likely mistakes that work within those types.
Linters, on the other hand, primarily target likely defects and can also be used to enforce subjective opinions.
@@ -95,24 +98,24 @@ function logFruit(value: "apple" | "banana" | "cherry") {
logFruit("banana");
```
-Another way of looking at the differences between linters and type checkers is that type checkers enforce what you *can* do, whereas linters enforce what you *should* do.
+Another way of looking at the differences between ESLint and TypeScript is that TypeScript enforces what you *can* do, whereas ESLint enforces what you *should* do.
### Granular Extensibility
Another difference between ESLint and TypeScript is how flexibly their areas of responsibility can be configured.
TypeScript is configured by a set list of compiler options on a project level.
-TypeScript's [`tsconfig.json` ("TSConfig") files](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allow for compiler options that change type checking for all files in the project.
+Its [`tsconfig.json` ("TSConfig") files](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allow for compiler options that change type checking for all files in the project.
Those compiler options are set by TypeScript and generally change large swathes of type checking behavior.
-Linters, on the other hand, run with a configurable set of lint rules.
+ESLint on the other hand, runs with a configurable set of lint rules.
Each lint rule can be granularly configured.
If you don't like a particular lint rule, you can always turn it off for a line, set of files, or your entire project.
-Linters can also be augmented by **plugins** that add new lint rules.
-Plugin-specific lint rules extend the breadth of code checks that linter configurations can pick and choose from.
+ESLint can also be augmented by **plugins** that add new lint rules.
+Plugin-specific lint rules extend the breadth of code checks that ESLint configurations can pick and choose from.
-For example, this ESLint configuration enables the recommended rules from [`eslint-plugin-jsx-a11y`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y), a plugin that adds checks for accessibility in JSX libraries such as Solid.js and React:
+For example, this ESLint configuration enables the recommended rules from [`eslint-plugin-jsx-a11y`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y), a plugin that adds checks for accessibility in projects using JSX libraries such as Solid.js and React:
```js title="eslint.config.js"
import js from "@eslint/js";
@@ -125,7 +128,8 @@ export default [
];
```
-A project using the JSX accessibility rules would then be told if they render a native `` tag without descriptive text per [`jsx-a11y/alt-text`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/blob/main/docs/rules/alt-text.md):
+A project using the JSX accessibility rules would then be told if their code violates common accessibility guidelines.
+For example, rendering a native `` tag without descriptive text would receive a report from [`jsx-a11y/alt-text`](https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/blob/main/docs/rules/alt-text.md):
```tsx
const MyComponent = () => ;
@@ -134,11 +138,11 @@ const MyComponent = () => ;
// img elements must have an alt prop, either with meaningful text, or an empty string for decorative images.
```
-By adding in rules from plugins, linter configurations can be tailored to the specific best practices and common issues to the frameworks a project is built with.
+By adding in rules from plugins, ESLint configurations can be tailored to the specific best practices and common issues to the frameworks a project is built with.
### Areas of Overlap
-Linters and type checkers operate differently and specialize in different areas of code defects.
+ESLint and TypeScript operate differently and specialize in different areas of code defects.
Some code defects straddle the line between "best practices" and "type safety", and so can be caught by both linting and type checking.
There are some core rules that are superseded by TypeScript's type checking.
@@ -200,14 +204,14 @@ That extra level of configurability provided by the `no-unused-vars` rules can a
> đź’ˇ See [`no-unused-binary-expressions`: From code review nit to ecosystem improvements](/blog/2024/10/code-review-nit-to-ecosystem-improvements) for more areas of code checking with partial overlap between linting and type checking.
-## Is a Linter Still Useful With a Type Checker?
+## Is a ESLint Still Useful With TypeScript?
**Yes.**
If you are using TypeScript, it is still very useful to use ESLint.
-In fact, linters and type checkers are at their most powerful when used in conjunction with each other.
+In fact, ESLint and TypeScript are at their most powerful when used in conjunction with each other.
-### Linters, With Type Information
+### ESLint, With Type Information
Traditional lint rules run on a single file at a time and have no knowledge of other files in the project.
They can't make decisions on files based on the contents of other files.
@@ -232,10 +236,10 @@ for (const name in getArrayOfNames()) {
}
```
-Augmenting the linter with information from the type checker makes for a more powerful set of lint rules.
+Augmenting ESLint with information from TypeScript makes for a more powerful set of lint rules.
See [Typed Linting: The Most Powerful TypeScript Linting Ever](https://typescript-eslint.io/blog/typed-linting) for more details on typed linting with typescript-eslint.
-### Type Checkers, With Linting
+### TypeScript, With Linting
TypeScript adds extra complexity to JavaScript.
That complexity is often worth it, but any added complexity brings with it the potential for misuse.
@@ -259,15 +263,15 @@ export function logObjectEntries(value: {}) {
logObjectEntries(0); // No type error!
```
-Enforcing language-specific best practices with a linter helps developers learn about and correctly use type checkers such as TypeScript.
+Enforcing language-specific best practices with ESLint helps developers learn about and correctly use TypeScript.
## Conclusion
Linters such as ESLint and type checkers such as TypeScript are both valuable assets for developers.
The two catch different areas of code defects and come with different philosophies around configurability and extensibility.
-* Type checkers check that code is "type-safe": enforcing what you *can* write
-* Linters check that code adheres to best practices and is consistent: enforcing what you *should* write
+* TypeScripts checks that code is "type-safe": enforcing what you *can* write
+* ESLint checks that code adheres to best practices and is consistent: enforcing what you *should* write
Put together, the two tools help projects write code with fewer bugs and more consistency.
We recommend that any project that uses TypeScript additionally uses ESLint.
From 142fcaf17e2360505ec34a0761eeb0fbd5e8e1d5 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Fri, 6 Dec 2024 10:14:11 -0500
Subject: [PATCH 07/26] A few more nits
---
...4-12-04-differences-between-linting-and-type-checking.md | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 177e0c9213..baa0b578dd 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -108,7 +108,7 @@ TypeScript is configured by a set list of compiler options on a project level.
Its [`tsconfig.json` ("TSConfig") files](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allow for compiler options that change type checking for all files in the project.
Those compiler options are set by TypeScript and generally change large swathes of type checking behavior.
-ESLint on the other hand, runs with a configurable set of lint rules.
+ESLint, on the other hand, runs with a configurable set of lint rules.
Each lint rule can be granularly configured.
If you don't like a particular lint rule, you can always turn it off for a line, set of files, or your entire project.
@@ -144,12 +144,12 @@ By adding in rules from plugins, ESLint configurations can be tailored to the sp
ESLint and TypeScript operate differently and specialize in different areas of code defects.
Some code defects straddle the line between "best practices" and "type safety", and so can be caught by both linting and type checking.
-There are some core rules that are superseded by TypeScript's type checking.
+Those defects can often be caught by both ESLint and TypeScript.
To make the most of both tools, we recommend:
* In your ESLint configuration file, use the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration), at least the [`tseslint.configs.recommended` configuration from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting), and any community plugins relevant to your project's libraries and frameworks
-* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict)
+* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict) to catch as many type safety issues as possible
typescript-eslint's recommended preset configs disable core ESLint rules that are not helpful with TypeScript.
The configs leave on any core ESLint rules that are useful alongside type checking.
From 7adb9d076c8a00fcb057d579c4c6125e19569e06 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Josh=20Goldberg=20=E2=9C=A8?=
Date: Mon, 9 Dec 2024 11:48:02 -0500
Subject: [PATCH 08/26] Apply suggestions from code review
Co-authored-by: Nicholas C. Zakas
---
.../2024-12-04-differences-between-linting-and-type-checking.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index baa0b578dd..6686913c77 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -65,7 +65,7 @@ TypeScript does not attempt to enforce general best practices — only that valu
TypeScript won't detect likely mistakes that work within those types.
Linters, on the other hand, primarily target likely defects and can also be used to enforce subjective opinions.
-ESLint and other linters catch issues that are may or may not be type-safe but are potential sources of bugs.
+ESLint and other linters catch issues that may or may not be type-safe but are potential sources of bugs.
Many developers rely on linters to make sure their code follows framework and language best practices.
For example, developers sometimes leave out the `break` or `return` at the end of a `switch` statement's `case`.
From d4d9bc1f888b0f59e8a3792105ae000b51d5bf5e Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Mon, 9 Dec 2024 11:51:30 -0500
Subject: [PATCH 09/26] Trim down and specify type checking
---
...-12-04-differences-between-linting-and-type-checking.md | 7 +++----
1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 6686913c77..5dd069f8ed 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -57,11 +57,10 @@ logUppercase(9001);
Compiled languages such as Java and Rust perform type checking as part of their compilation step.
Because JavaScript is an interpreted language, TypeScript is run separately.
-Type checkers generally do not attempt to look for defects that are only likely to occur.
-They generally only look for uses of code that are certainly wrong.
+TypeScript generally does not attempt to look for defects that are only likely to occur.
+It generally only looks for uses of code that are certainly wrong.
-Nor do type checkers enforce subjective opinions that might change between projects.
-TypeScript does not attempt to enforce general best practices — only that values are used in type-safe ways.
+Nor does the type checking in TypeScript enforce subjective opinions that might change between projects.
TypeScript won't detect likely mistakes that work within those types.
Linters, on the other hand, primarily target likely defects and can also be used to enforce subjective opinions.
From 029b74c048a772e745fe03419a68e1482b0037ba Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Mon, 9 Dec 2024 11:51:51 -0500
Subject: [PATCH 10/26] Trim down and specify type checking even more
---
.../2024-12-04-differences-between-linting-and-type-checking.md | 2 --
1 file changed, 2 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 5dd069f8ed..3c6c2eb7c8 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -59,9 +59,7 @@ Because JavaScript is an interpreted language, TypeScript is run separately.
TypeScript generally does not attempt to look for defects that are only likely to occur.
It generally only looks for uses of code that are certainly wrong.
-
Nor does the type checking in TypeScript enforce subjective opinions that might change between projects.
-TypeScript won't detect likely mistakes that work within those types.
Linters, on the other hand, primarily target likely defects and can also be used to enforce subjective opinions.
ESLint and other linters catch issues that may or may not be type-safe but are potential sources of bugs.
From b4293d94557fe9597fd03aea82c015f76d26b0d4 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Mon, 9 Dec 2024 12:10:41 -0500
Subject: [PATCH 11/26] good chance
---
.../2024-12-04-differences-between-linting-and-type-checking.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 3c6c2eb7c8..b28f84bb51 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -10,7 +10,7 @@ tags:
- Linting
---
-If you're a JavaScript developer today, you're probably using ESLint and/or TypeScript to assist development.
+If you're a JavaScript developer today, there's a good chance you're using ESLint and/or TypeScript to assist development.
Those two tools are common examples of their kind of tooling: ESLint is a common *linter*, whereas TypeScript is a common *type checker*.
Linters and type checkers are two kinds of tools that both analyze code and report on detected issues.
From cec8a698038ce4f6c5a98f7cd8b468bc344db958 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Mon, 9 Dec 2024 12:45:54 -0500
Subject: [PATCH 12/26] Small bits of proofreading
---
...4-12-04-differences-between-linting-and-type-checking.md | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index b28f84bb51..85e910fd0d 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -26,7 +26,7 @@ As such, dynamic analysis brings with it the inherent danger of executing malici
Static analysis can be immensely helpful for improving code readability, reliability, and overall quality.
Many developers rely on static analysis to enforce consistent code formatting and style, to ensure code is well-documented, and to catch likely bugs.
-Because static analysis runs on source code, it can suggest improvements in editors, as code is written.
+Because static analysis runs on source code, it can suggest improvements in editors as code is written.
We'll focus in this blog post on ESLint and TypeScript:
@@ -145,7 +145,7 @@ Those defects can often be caught by both ESLint and TypeScript.
To make the most of both tools, we recommend:
-* In your ESLint configuration file, use the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration), at least the [`tseslint.configs.recommended` configuration from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting), and any community plugins relevant to your project's libraries and frameworks
+* In your ESLint configuration file, use the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration), at least the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting), and any community plugins relevant to your project's libraries and frameworks
* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict) to catch as many type safety issues as possible
typescript-eslint's recommended preset configs disable core ESLint rules that are not helpful with TypeScript.
@@ -174,7 +174,7 @@ declare function registerCallback(callback: Callback): void;
registerCallback((_, message) => console.log(message));
```
-Unused variables in JavaScript can also be caught by ESLint's [`no-unused-vars`](https://eslint.org/docs/latest/rules/no-unused-vars) rule; when in TypeScript code, the [`@typescript-eslint/no-unused-vars`](https://typescript-eslint.io/rules/no-unused-vars) is preferred instead.
+Unused variables in JavaScript can also be caught by ESLint's [`no-unused-vars`](https://eslint.org/docs/latest/rules/no-unused-vars) rule; when in TypeScript code, the [`@typescript-eslint/no-unused-vars`](https://typescript-eslint.io/rules/no-unused-vars) is preferable instead.
The lint rules by default also ignore variables whose name begins with `_`.
They additionally ignore parameters that come before any parameter that is itself used.
From 8674afe22af8225ca3573a7a25786ba987ecc147 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Josh=20Goldberg=20=E2=9C=A8?=
Date: Thu, 16 Jan 2025 11:31:16 -0500
Subject: [PATCH 13/26] Apply suggestions from code review
Co-authored-by: Nicholas C. Zakas
---
...ences-between-linting-and-type-checking.md | 81 +++++++++----------
1 file changed, 37 insertions(+), 44 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 85e910fd0d..66a496432b 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -1,7 +1,7 @@
---
layout: post
-title: "Differences between linting and type checking"
-teaser: "Linters such as ESLint and type checkers such as TypeScript catch different areas of code defects — and are best used in conjunction with each other."
+title: "Differences between ESLint and TypeScript"
+teaser: "Linters such as ESLint and type checkers such as TypeScript catch different areas of code defects and are best used in conjunction with each other."
authors:
- joshuakgoldberg
categories:
@@ -10,13 +10,12 @@ tags:
- Linting
---
-If you're a JavaScript developer today, there's a good chance you're using ESLint and/or TypeScript to assist development.
-Those two tools are common examples of their kind of tooling: ESLint is a common *linter*, whereas TypeScript is a common *type checker*.
+If you're a JavaScript developer today, there's a good chance you're using a combination of ESLint and TypeScript to assist development.
+These tools perform similar but different functions. ESLint is a *linter*, whereas TypeScript is a *type checker*.
-Linters and type checkers are two kinds of tools that both analyze code and report on detected issues.
-They may seem similar at first.
-They both fall under the category of *static analysis*.
-However, the two kinds of tools detect very different issues and are useful in different ways.
+Linters and type checkers are two kinds of *static analysis* tool that analyze code and report on detected issues. While they may seem similar at first, the linters and type checkers detect different categories of issues and are useful in different ways.
+
+To understand these differences, it's first helpful to understand what static analysis is and why it's useful.
## What is static analysis?
@@ -28,7 +27,7 @@ Static analysis can be immensely helpful for improving code readability, reliabi
Many developers rely on static analysis to enforce consistent code formatting and style, to ensure code is well-documented, and to catch likely bugs.
Because static analysis runs on source code, it can suggest improvements in editors as code is written.
-We'll focus in this blog post on ESLint and TypeScript:
+In this blog post, we'll focus on ESLint and TypeScript, and the different ways in which they perform static analysis.
* **ESLint**: executes individually configurable checks known as "lint rules"
* **TypeScript**: collects all files into a full understanding of the project
@@ -39,10 +38,10 @@ We'll explore the different ways the two use information from analyzing your cod
## Digging deeper into linting vs. type checking
-Type checkers make sure the *intent* behind values in code matches the *usage* of those values.
-They check that code is "type-safe": values are used according to how their types are described as being allowed.
+Type checkers ensure that values are used only in ways that are allowed by the value's type. Compiled languages, like Java, perform type checking during the compilation phase. Because JavaScript has no way to indicate the intended type of a binding, it cannot perform type checking on its own. That's where TypeScript comes in.
-For example, TypeScript would report a type error on the following `logUppercase(9001)` call, because `logUppercase` is declared as receiving a `string` rather than a `number`:
+By allowing explicit type annotations (and the implicit detection of some types), TypeScript overlays type information on top of JavaScript code to perform type checking similar to what's found in compiled languages.
+For example, TypeScript reports a type error on the following `logUppercase(9001)` call, because `logUppercase` is declared to receive a `string` rather than a `number`:
```ts
function logUppercase(text: string) {
@@ -54,14 +53,10 @@ logUppercase(9001);
// Argument of type 'number' is not assignable to parameter of type 'string'.
```
-Compiled languages such as Java and Rust perform type checking as part of their compilation step.
-Because JavaScript is an interpreted language, TypeScript is run separately.
-TypeScript generally does not attempt to look for defects that are only likely to occur.
-It generally only looks for uses of code that are certainly wrong.
-Nor does the type checking in TypeScript enforce subjective opinions that might change between projects.
+TypeScript focuses on reporting known errors rather than potential problems; there is nothing subjective about the errors that TypeScript reports, nor is there a way to implement project-specific preferences.
-Linters, on the other hand, primarily target likely defects and can also be used to enforce subjective opinions.
+Linters, on the other hand, primarily report likely defects and can also be used to enforce subjective opinions.
ESLint and other linters catch issues that may or may not be type-safe but are potential sources of bugs.
Many developers rely on linters to make sure their code follows framework and language best practices.
@@ -99,16 +94,13 @@ Another way of looking at the differences between ESLint and TypeScript is that
### Granular Extensibility
-Another difference between ESLint and TypeScript is how flexibly their areas of responsibility can be configured.
+Another difference between ESLint and TypeScript is in granularity of configuration.
TypeScript is configured by a set list of compiler options on a project level.
-Its [`tsconfig.json` ("TSConfig") files](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allow for compiler options that change type checking for all files in the project.
+The [`tsconfig.json` file](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allows you to set compiler options that change type checking for all files in the project.
Those compiler options are set by TypeScript and generally change large swathes of type checking behavior.
-ESLint, on the other hand, runs with a configurable set of lint rules.
-Each lint rule can be granularly configured.
-If you don't like a particular lint rule, you can always turn it off for a line, set of files, or your entire project.
-
+ESLint, on the other hand, runs with a set of individually configurable lint rules. If you don't like a particular lint rule, you can turn it off for a line, set of files, or your entire project.
ESLint can also be augmented by **plugins** that add new lint rules.
Plugin-specific lint rules extend the breadth of code checks that ESLint configurations can pick and choose from.
@@ -139,30 +131,31 @@ By adding in rules from plugins, ESLint configurations can be tailored to the sp
### Areas of Overlap
-ESLint and TypeScript operate differently and specialize in different areas of code defects.
-Some code defects straddle the line between "best practices" and "type safety", and so can be caught by both linting and type checking.
-Those defects can often be caught by both ESLint and TypeScript.
+While ESLint and TypeScript operate differently and specialize in different areas of code defects, there is some overlap. Specific types of code defects straddle the line between "best practices" and "type safety," and so can be caught by both tools.
-To make the most of both tools, we recommend:
+We recommend using both ESLint and TypeScript in your TypeScript projects to ensure you're catching the widest number and types of defects. Here are a few steps to get you started:
-* In your ESLint configuration file, use the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration), at least the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting), and any community plugins relevant to your project's libraries and frameworks
+* In your ESLint configuration file, use:
+ - the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration)
+ - the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting)
+ - any community plugins relevant to your project's libraries and frameworks
* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict) to catch as many type safety issues as possible
-typescript-eslint's recommended preset configs disable core ESLint rules that are not helpful with TypeScript.
-The configs leave on any core ESLint rules that are useful alongside type checking.
+**Note:** typescript-eslint's `tseslint.configs.recommended` disable core ESLint rules that are not helpful with TypeScript.
+The config leaves on any core ESLint rules that are useful alongside type checking.
#### Unused Locals and Parameters
The only TypeScript compiler options we recommend keeping off when using linting are those that enable checking for unused variables:
-* [`noUnusedLocals`](https://www.typescriptlang.org/tsconfig/#noUnusedLocals): which reports on unused declared local variables
-* [`noUnusedParameters`](https://www.typescriptlang.org/tsconfig/#noUnusedParameters): which reports on unused function parameters
+* [`noUnusedLocals`](https://www.typescriptlang.org/tsconfig/#noUnusedLocals) - reports on unused declared local variables
+* [`noUnusedParameters`](https://www.typescriptlang.org/tsconfig/#noUnusedParameters) - reports on unused function parameters
-Those compiler options are useful when not using a linter.
-However, they aren't configurable the way lint rules are, and so can't be configured to higher or lower strictness levels per a project's preferences.
-The compiler options are hardcoded to always ignore any variable whose name begins with `_`.
+These compiler options are useful when not using ESLint.
+However, they aren't configurable the way lint rules are, and so can't be configured to higher or lower strictness levels based on a project's preferences.
+For example, the compiler options are hardcoded to always ignore any variable whose name begins with `_` while ESLint's `no-unused-vars` doesn't treat these variables any differently until configured to do so.
-As an example, the following `registerCallback` function declares two parameters for its callbacks -`id` and `message`- but the developer using it only needed `message`.
+As an example, the following `registerCallback` function declares two parameters for its callbacks,`id` and `message`, but the developer using it only needed `message`.
TypeScript's `noUnusedParameters` compiler option would not flag the unused parameter `_`:
```ts
@@ -201,16 +194,16 @@ That extra level of configurability provided by the `no-unused-vars` rules can a
> đź’ˇ See [`no-unused-binary-expressions`: From code review nit to ecosystem improvements](/blog/2024/10/code-review-nit-to-ecosystem-improvements) for more areas of code checking with partial overlap between linting and type checking.
-## Is a ESLint Still Useful With TypeScript?
+## Is ESLint Useful With TypeScript?
**Yes.**
If you are using TypeScript, it is still very useful to use ESLint.
In fact, ESLint and TypeScript are at their most powerful when used in conjunction with each other.
-### ESLint, With Type Information
+### ESLint with Type Information
-Traditional lint rules run on a single file at a time and have no knowledge of other files in the project.
+Traditional ESLint rules run on a single file at a time and have no knowledge of other files in the project.
They can't make decisions on files based on the contents of other files.
However, if your project is set up using TypeScript, you can opt into "type checked" lint rules: rules that can pull in type information.
@@ -236,11 +229,11 @@ for (const name in getArrayOfNames()) {
Augmenting ESLint with information from TypeScript makes for a more powerful set of lint rules.
See [Typed Linting: The Most Powerful TypeScript Linting Ever](https://typescript-eslint.io/blog/typed-linting) for more details on typed linting with typescript-eslint.
-### TypeScript, With Linting
+### TypeScript with Linting
TypeScript adds extra complexity to JavaScript.
That complexity is often worth it, but any added complexity brings with it the potential for misuse.
-Linters are useful for stopping developers from making TypeScript-specific blunders in code.
+ESLint is useful for stopping developers from making TypeScript-specific blunders in code.
For example, TypeScript's `{}` ("empty object") type is often misused by developers new to TypeScript.
It visually looks like it should mean any `object`, but actually means any non-`null`, non-`undefined` value --- including primitives such as `number`s and `string`s.
@@ -267,8 +260,8 @@ Enforcing language-specific best practices with ESLint helps developers learn ab
Linters such as ESLint and type checkers such as TypeScript are both valuable assets for developers.
The two catch different areas of code defects and come with different philosophies around configurability and extensibility.
-* TypeScripts checks that code is "type-safe": enforcing what you *can* write
-* ESLint checks that code adheres to best practices and is consistent: enforcing what you *should* write
+* TypeScripts checks that code is "type-safe", enforcing what you *can* write.
+* ESLint checks that code adheres to best practices and is consistent, enforcing what you *should* write.
Put together, the two tools help projects write code with fewer bugs and more consistency.
We recommend that any project that uses TypeScript additionally uses ESLint.
From 5e81d1e1a1b1d6b677dfa9d8857f4ac89f8c0ab2 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 11:38:21 -0500
Subject: [PATCH 14/26] Lint fixes
---
...12-04-differences-between-linting-and-type-checking.md | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 66a496432b..2d76f602bc 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -40,7 +40,7 @@ We'll explore the different ways the two use information from analyzing your cod
Type checkers ensure that values are used only in ways that are allowed by the value's type. Compiled languages, like Java, perform type checking during the compilation phase. Because JavaScript has no way to indicate the intended type of a binding, it cannot perform type checking on its own. That's where TypeScript comes in.
-By allowing explicit type annotations (and the implicit detection of some types), TypeScript overlays type information on top of JavaScript code to perform type checking similar to what's found in compiled languages.
+By allowing explicit type annotations (and the implicit detection of some types), TypeScript overlays type information on top of JavaScript code to perform type checking similar to what's found in compiled languages.
For example, TypeScript reports a type error on the following `logUppercase(9001)` call, because `logUppercase` is declared to receive a `string` rather than a `number`:
```ts
@@ -136,9 +136,9 @@ While ESLint and TypeScript operate differently and specialize in different area
We recommend using both ESLint and TypeScript in your TypeScript projects to ensure you're catching the widest number and types of defects. Here are a few steps to get you started:
* In your ESLint configuration file, use:
- - the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration)
- - the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting)
- - any community plugins relevant to your project's libraries and frameworks
+ * the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration)
+ * the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting)
+ * any community plugins relevant to your project's libraries and frameworks
* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict) to catch as many type safety issues as possible
**Note:** typescript-eslint's `tseslint.configs.recommended` disable core ESLint rules that are not helpful with TypeScript.
From b717cd51ec186cdfeb020ded2c4b435906d89492 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 11:38:32 -0500
Subject: [PATCH 15/26] fix: no /typed-linting in tseslint.configs.recommended
---
.../2024-12-04-differences-between-linting-and-type-checking.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 2d76f602bc..e835dc354f 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -137,7 +137,7 @@ We recommend using both ESLint and TypeScript in your TypeScript projects to ens
* In your ESLint configuration file, use:
* the [ESLint `js.configs.recommended` config](https://eslint.org/docs/latest/use/getting-started#configuration)
- * the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started/typed-linting)
+ * the [`tseslint.configs.recommended` config from typescript-eslint](https://typescript-eslint.io/getting-started)
* any community plugins relevant to your project's libraries and frameworks
* In your TypeScript configuration file, enable [`strict` mode](https://www.typescriptlang.org/tsconfig/#strict) to catch as many type safety issues as possible
From 3e818472e51b51ae888a59ac3010da0d1947ef5d Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 11:52:47 -0500
Subject: [PATCH 16/26] fix: more feedback
---
...2-04-differences-between-linting-and-type-checking.md | 9 ++++-----
1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index e835dc354f..a2be5d36ed 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -29,8 +29,7 @@ Because static analysis runs on source code, it can suggest improvements in edit
In this blog post, we'll focus on ESLint and TypeScript, and the different ways in which they perform static analysis.
-* **ESLint**: executes individually configurable checks known as "lint rules"
-* **TypeScript**: collects all files into a full understanding of the project
+ESLint's static analysis is organized as a series of individually configured lint rules. Because no two rules interact with one another, you can safely turn each rule on and off depending on your preferences. While TypeScript has some individually configured options, the majority of the analysis is performed in the type checking functionality.
ESLint and TypeScript use some of the same forms of analysis to detect defects in code.
They both analyze how scopes and variables are created and used in code, and can catch issues such as referencing a variable that doesn't exist.
@@ -98,7 +97,7 @@ Another difference between ESLint and TypeScript is in granularity of configurat
TypeScript is configured by a set list of compiler options on a project level.
The [`tsconfig.json` file](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allows you to set compiler options that change type checking for all files in the project.
-Those compiler options are set by TypeScript and generally change large swathes of type checking behavior.
+Those compiler options are set globally for TypeScript and generally change large swathes of type checking behavior.
ESLint, on the other hand, runs with a set of individually configurable lint rules. If you don't like a particular lint rule, you can turn it off for a line, set of files, or your entire project.
ESLint can also be augmented by **plugins** that add new lint rules.
@@ -168,9 +167,9 @@ registerCallback((_, message) => console.log(message));
```
Unused variables in JavaScript can also be caught by ESLint's [`no-unused-vars`](https://eslint.org/docs/latest/rules/no-unused-vars) rule; when in TypeScript code, the [`@typescript-eslint/no-unused-vars`](https://typescript-eslint.io/rules/no-unused-vars) is preferable instead.
-The lint rules by default also ignore variables whose name begins with `_`.
-They additionally ignore parameters that come before any parameter that is itself used.
+The lint rules can be configured to ignore variables whose name begins with `_`.
+Additionally, the lint rules by default ignore parameters that come before any parameter that is itself used.
Some projects prefer to never allow unused parameters regardless of name or position.
These stricter preferences help prevent API designs that lead developers to create many unused parameters.
From 6324ccec2186e7067d8d49d5c1d4b27972abefb0 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 11:55:10 -0500
Subject: [PATCH 17/26] Mention typed linting performance
---
.../2024-12-04-differences-between-linting-and-type-checking.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index a2be5d36ed..785ace3a10 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -225,7 +225,7 @@ for (const name in getArrayOfNames()) {
}
```
-Augmenting ESLint with information from TypeScript makes for a more powerful set of lint rules.
+Typed linting comes at the cost of slowing down linting to roughly the speed of type-checking, but makes available a more powerful set of lint rules.
See [Typed Linting: The Most Powerful TypeScript Linting Ever](https://typescript-eslint.io/blog/typed-linting) for more details on typed linting with typescript-eslint.
### TypeScript with Linting
From 2036d3c29d2e0dccdcaac112200806ae93fb2108 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 12:00:00 -0500
Subject: [PATCH 18/26] Ordering: lint, then type check
---
...ences-between-linting-and-type-checking.md | 48 +++++++++----------
1 file changed, 24 insertions(+), 24 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index 785ace3a10..e9c52b9761 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -37,25 +37,7 @@ We'll explore the different ways the two use information from analyzing your cod
## Digging deeper into linting vs. type checking
-Type checkers ensure that values are used only in ways that are allowed by the value's type. Compiled languages, like Java, perform type checking during the compilation phase. Because JavaScript has no way to indicate the intended type of a binding, it cannot perform type checking on its own. That's where TypeScript comes in.
-
-By allowing explicit type annotations (and the implicit detection of some types), TypeScript overlays type information on top of JavaScript code to perform type checking similar to what's found in compiled languages.
-For example, TypeScript reports a type error on the following `logUppercase(9001)` call, because `logUppercase` is declared to receive a `string` rather than a `number`:
-
-```ts
-function logUppercase(text: string) {
- console.log(text.toUpperCase());
-}
-
-logUppercase(9001);
-// ~~~~
-// Argument of type 'number' is not assignable to parameter of type 'string'.
-```
-
-
-TypeScript focuses on reporting known errors rather than potential problems; there is nothing subjective about the errors that TypeScript reports, nor is there a way to implement project-specific preferences.
-
-Linters, on the other hand, primarily report likely defects and can also be used to enforce subjective opinions.
+Linters primarily report likely defects and can also be used to enforce subjective opinions.
ESLint and other linters catch issues that may or may not be type-safe but are potential sources of bugs.
Many developers rely on linters to make sure their code follows framework and language best practices.
@@ -89,17 +71,30 @@ function logFruit(value: "apple" | "banana" | "cherry") {
logFruit("banana");
```
+Type checkers, on the other hand, ensure that values are used only in ways that are allowed by the value's type. Compiled languages, like Java, perform type checking during the compilation phase. Because JavaScript has no way to indicate the intended type of a binding, it cannot perform type checking on its own. That's where TypeScript comes in.
+
+By allowing explicit type annotations (and the implicit detection of some types), TypeScript overlays type information on top of JavaScript code to perform type checking similar to what's found in compiled languages.
+For example, TypeScript reports a type error on the following `logUppercase(9001)` call, because `logUppercase` is declared to receive a `string` rather than a `number`:
+
+```ts
+function logUppercase(text: string) {
+ console.log(text.toUpperCase());
+}
+
+logUppercase(9001);
+// ~~~~
+// Argument of type 'number' is not assignable to parameter of type 'string'.
+```
+
+TypeScript focuses on reporting known errors rather than potential problems; there is nothing subjective about the errors that TypeScript reports, nor is there a way to implement project-specific preferences.
+
Another way of looking at the differences between ESLint and TypeScript is that TypeScript enforces what you *can* do, whereas ESLint enforces what you *should* do.
### Granular Extensibility
Another difference between ESLint and TypeScript is in granularity of configuration.
-TypeScript is configured by a set list of compiler options on a project level.
-The [`tsconfig.json` file](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allows you to set compiler options that change type checking for all files in the project.
-Those compiler options are set globally for TypeScript and generally change large swathes of type checking behavior.
-
-ESLint, on the other hand, runs with a set of individually configurable lint rules. If you don't like a particular lint rule, you can turn it off for a line, set of files, or your entire project.
+ESLint runs with a set of individually configurable lint rules. If you don't like a particular lint rule, you can turn it off for a line, set of files, or your entire project.
ESLint can also be augmented by **plugins** that add new lint rules.
Plugin-specific lint rules extend the breadth of code checks that ESLint configurations can pick and choose from.
@@ -128,6 +123,11 @@ const MyComponent = () => ;
By adding in rules from plugins, ESLint configurations can be tailored to the specific best practices and common issues to the frameworks a project is built with.
+TypeScript, on the other hand, is configured by a set list of compiler options on a project level.
+The [`tsconfig.json` file](https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) allows you to set compiler options that change type checking for all files in the project.
+Those compiler options are set globally for TypeScript and generally change large swathes of type checking behavior.
+TypeScript does not allow compiler options to be different across different files in a single project.
+
### Areas of Overlap
While ESLint and TypeScript operate differently and specialize in different areas of code defects, there is some overlap. Specific types of code defects straddle the line between "best practices" and "type safety," and so can be caught by both tools.
From 4e7b7e53e67c071f1c19771ee8173b21c5442288 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 12:05:28 -0500
Subject: [PATCH 19/26] nit: remove added newlines
---
src/_data/all_authors.json | 2 +-
src/_data/team.json | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/_data/all_authors.json b/src/_data/all_authors.json
index 6f25a3f3e4..4f9e3a4fce 100644
--- a/src/_data/all_authors.json
+++ b/src/_data/all_authors.json
@@ -213,4 +213,4 @@
"twitter_username": "JoshuaKGoldberg2",
"location": "undefined"
}
-}
+}
\ No newline at end of file
diff --git a/src/_data/team.json b/src/_data/team.json
index fae94600f9..c1e0ce1119 100644
--- a/src/_data/team.json
+++ b/src/_data/team.json
@@ -458,4 +458,4 @@
"location": "Canada"
}
]
-}
+}
\ No newline at end of file
From 9b6e0b7149d8aa0d4b1c19020dd1f1629a75cda2 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 12:11:03 -0500
Subject: [PATCH 20/26] One more editing pass
---
...04-differences-between-linting-and-type-checking.md | 10 ++++------
1 file changed, 4 insertions(+), 6 deletions(-)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
index e9c52b9761..3e11ee1255 100644
--- a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
+++ b/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
@@ -13,7 +13,7 @@ tags:
If you're a JavaScript developer today, there's a good chance you're using a combination of ESLint and TypeScript to assist development.
These tools perform similar but different functions. ESLint is a *linter*, whereas TypeScript is a *type checker*.
-Linters and type checkers are two kinds of *static analysis* tool that analyze code and report on detected issues. While they may seem similar at first, the linters and type checkers detect different categories of issues and are useful in different ways.
+Linters and type checkers are two kinds of *static analysis* tooling that analyze code and report on detected issues. While they may seem similar at first, linters and type checkers detect different categories of issues and are useful in different ways.
To understand these differences, it's first helpful to understand what static analysis is and why it's useful.
@@ -27,8 +27,6 @@ Static analysis can be immensely helpful for improving code readability, reliabi
Many developers rely on static analysis to enforce consistent code formatting and style, to ensure code is well-documented, and to catch likely bugs.
Because static analysis runs on source code, it can suggest improvements in editors as code is written.
-In this blog post, we'll focus on ESLint and TypeScript, and the different ways in which they perform static analysis.
-
ESLint's static analysis is organized as a series of individually configured lint rules. Because no two rules interact with one another, you can safely turn each rule on and off depending on your preferences. While TypeScript has some individually configured options, the majority of the analysis is performed in the type checking functionality.
ESLint and TypeScript use some of the same forms of analysis to detect defects in code.
@@ -154,7 +152,7 @@ These compiler options are useful when not using ESLint.
However, they aren't configurable the way lint rules are, and so can't be configured to higher or lower strictness levels based on a project's preferences.
For example, the compiler options are hardcoded to always ignore any variable whose name begins with `_` while ESLint's `no-unused-vars` doesn't treat these variables any differently until configured to do so.
-As an example, the following `registerCallback` function declares two parameters for its callbacks,`id` and `message`, but the developer using it only needed `message`.
+As an example, the following `registerCallback` function declares two parameters for its callbacks, `id`, and `message`, but the developer using it only needed `message`.
TypeScript's `noUnusedParameters` compiler option would not flag the unused parameter `_`:
```ts
@@ -189,7 +187,7 @@ registerCallback((_, message) => console.log(message));
// '_' is declared but never used.
```
-That extra level of configurability provided by the `no-unused-vars` rules can allow them to act as more granularly configurable versions of their equivalent TypeScript compiler options.
+That extra level of configurability provided by the `no-unused-vars` rules allows them to act as more granularly configurable versions of their equivalent TypeScript compiler options.
> đź’ˇ See [`no-unused-binary-expressions`: From code review nit to ecosystem improvements](/blog/2024/10/code-review-nit-to-ecosystem-improvements) for more areas of code checking with partial overlap between linting and type checking.
@@ -259,8 +257,8 @@ Enforcing language-specific best practices with ESLint helps developers learn ab
Linters such as ESLint and type checkers such as TypeScript are both valuable assets for developers.
The two catch different areas of code defects and come with different philosophies around configurability and extensibility.
-* TypeScripts checks that code is "type-safe", enforcing what you *can* write.
* ESLint checks that code adheres to best practices and is consistent, enforcing what you *should* write.
+* TypeScripts checks that code is "type-safe", enforcing what you *can* write.
Put together, the two tools help projects write code with fewer bugs and more consistency.
We recommend that any project that uses TypeScript additionally uses ESLint.
From ddd0633c8a8b9f2aaf21248189caefaeddc1f8c1 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 12:13:12 -0500
Subject: [PATCH 21/26] Adjust title
---
...md => 2025-01-09-differences-between-eslint-and-typescript.md} | 0
1 file changed, 0 insertions(+), 0 deletions(-)
rename src/content/blog/{2024-12-04-differences-between-linting-and-type-checking.md => 2025-01-09-differences-between-eslint-and-typescript.md} (100%)
diff --git a/src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md b/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
similarity index 100%
rename from src/content/blog/2024-12-04-differences-between-linting-and-type-checking.md
rename to src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
From a36bf9b1f3ddd46b084fad1daf18defde09d64e6 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Thu, 16 Jan 2025 12:13:37 -0500
Subject: [PATCH 22/26] Added a 'Type Checking' tag
---
.../blog/2025-01-09-differences-between-eslint-and-typescript.md | 1 +
1 file changed, 1 insertion(+)
diff --git a/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md b/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
index 3e11ee1255..76ee578d86 100644
--- a/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
+++ b/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
@@ -8,6 +8,7 @@ categories:
- Storytime
tags:
- Linting
+ - Type Checking
---
If you're a JavaScript developer today, there's a good chance you're using a combination of ESLint and TypeScript to assist development.
From 3d89174c72098397e2789f4755f7f80a376c9a01 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Josh=20Goldberg=20=E2=9C=A8?=
Date: Thu, 16 Jan 2025 12:15:25 -0500
Subject: [PATCH 23/26] Update src/_data/all_authors.json
---
src/_data/all_authors.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/_data/all_authors.json b/src/_data/all_authors.json
index 4f9e3a4fce..aefcd5a29f 100644
--- a/src/_data/all_authors.json
+++ b/src/_data/all_authors.json
@@ -210,7 +210,7 @@
"bio": "An open source maintainer in the TypeScript ecosystem.",
"github_username": "JoshuaKGoldberg",
"mastodon_url": "https://fosstodon.org/@JoshuaKGoldberg",
- "twitter_username": "JoshuaKGoldberg2",
+ "twitter_username": "JoshuaKGoldberg",
"location": "undefined"
}
}
\ No newline at end of file
From dd1514523801ade895cec6bb208014b2d405559b Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Josh=20Goldberg=20=E2=9C=A8?=
Date: Fri, 17 Jan 2025 14:24:05 -0500
Subject: [PATCH 24/26] Apply suggestions from code review
Co-authored-by: Nicholas C. Zakas
---
...1-09-differences-between-eslint-and-typescript.md | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md b/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
index 76ee578d86..3047452e92 100644
--- a/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
+++ b/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
@@ -89,7 +89,7 @@ TypeScript focuses on reporting known errors rather than potential problems; the
Another way of looking at the differences between ESLint and TypeScript is that TypeScript enforces what you *can* do, whereas ESLint enforces what you *should* do.
-### Granular Extensibility
+### Granular extensibility
Another difference between ESLint and TypeScript is in granularity of configuration.
@@ -127,7 +127,7 @@ The [`tsconfig.json` file](https://www.typescriptlang.org/docs/handbook/tsconfig
Those compiler options are set globally for TypeScript and generally change large swathes of type checking behavior.
TypeScript does not allow compiler options to be different across different files in a single project.
-### Areas of Overlap
+### Areas of overlap
While ESLint and TypeScript operate differently and specialize in different areas of code defects, there is some overlap. Specific types of code defects straddle the line between "best practices" and "type safety," and so can be caught by both tools.
@@ -142,7 +142,7 @@ We recommend using both ESLint and TypeScript in your TypeScript projects to ens
**Note:** typescript-eslint's `tseslint.configs.recommended` disable core ESLint rules that are not helpful with TypeScript.
The config leaves on any core ESLint rules that are useful alongside type checking.
-#### Unused Locals and Parameters
+#### Unused locals and parameters
The only TypeScript compiler options we recommend keeping off when using linting are those that enable checking for unused variables:
@@ -192,14 +192,14 @@ That extra level of configurability provided by the `no-unused-vars` rules allow
> đź’ˇ See [`no-unused-binary-expressions`: From code review nit to ecosystem improvements](/blog/2024/10/code-review-nit-to-ecosystem-improvements) for more areas of code checking with partial overlap between linting and type checking.
-## Is ESLint Useful With TypeScript?
+## Is ESLint useful with TypeScript?
**Yes.**
If you are using TypeScript, it is still very useful to use ESLint.
In fact, ESLint and TypeScript are at their most powerful when used in conjunction with each other.
-### ESLint with Type Information
+### ESLint with type information
Traditional ESLint rules run on a single file at a time and have no knowledge of other files in the project.
They can't make decisions on files based on the contents of other files.
@@ -227,7 +227,7 @@ for (const name in getArrayOfNames()) {
Typed linting comes at the cost of slowing down linting to roughly the speed of type-checking, but makes available a more powerful set of lint rules.
See [Typed Linting: The Most Powerful TypeScript Linting Ever](https://typescript-eslint.io/blog/typed-linting) for more details on typed linting with typescript-eslint.
-### TypeScript with Linting
+### TypeScript with linting
TypeScript adds extra complexity to JavaScript.
That complexity is often worth it, but any added complexity brings with it the potential for misuse.
From 3c6d7d4583b1b83df6a1d0cbfca12b65656535e4 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Fri, 17 Jan 2025 14:24:29 -0500
Subject: [PATCH 25/26] chore: move date to Monday
---
...md => 2025-01-19-differences-between-eslint-and-typescript.md} | 0
1 file changed, 0 insertions(+), 0 deletions(-)
rename src/content/blog/{2025-01-09-differences-between-eslint-and-typescript.md => 2025-01-19-differences-between-eslint-and-typescript.md} (100%)
diff --git a/src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md b/src/content/blog/2025-01-19-differences-between-eslint-and-typescript.md
similarity index 100%
rename from src/content/blog/2025-01-09-differences-between-eslint-and-typescript.md
rename to src/content/blog/2025-01-19-differences-between-eslint-and-typescript.md
From 013aaea890ed2ce0ae71cddfd66c3387ef854151 Mon Sep 17 00:00:00 2001
From: Josh Goldberg
Date: Tue, 21 Jan 2025 08:03:35 -0500
Subject: [PATCH 26/26] Push date to 01-28
---
...md => 2025-01-28-differences-between-eslint-and-typescript.md} | 0
1 file changed, 0 insertions(+), 0 deletions(-)
rename src/content/blog/{2025-01-19-differences-between-eslint-and-typescript.md => 2025-01-28-differences-between-eslint-and-typescript.md} (100%)
diff --git a/src/content/blog/2025-01-19-differences-between-eslint-and-typescript.md b/src/content/blog/2025-01-28-differences-between-eslint-and-typescript.md
similarity index 100%
rename from src/content/blog/2025-01-19-differences-between-eslint-and-typescript.md
rename to src/content/blog/2025-01-28-differences-between-eslint-and-typescript.md