no-deprecated
Disallow using code marked as
@deprecated
.
Extending "plugin:@typescript-eslint/strict-type-checked"
in an ESLint configuration enables this rule.
This rule requires type information to run.
The JSDoc @deprecated
tag can be used to document some piece of code being deprecated.
It's best to avoid using code marked as deprecated.
This rule reports on any references to code marked as @deprecated
.
TypeScript recognizes the @deprecated
tag, allowing editors to visually indicate deprecated code — usually with a strikethrough.
However, TypeScript doesn't report type errors for deprecated code on its own.
- Flat Config
- Legacy Config
export default tseslint.config({
rules: {
"@typescript-eslint/no-deprecated": "error"
}
});
module.exports = {
"rules": {
"@typescript-eslint/no-deprecated": "error"
}
};
Try this rule in the playground ↗
Examples
- ❌ Incorrect
- ✅ Correct
/** @deprecated Use apiV2 instead. */
declare function apiV1(): Promise<string>;
declare function apiV2(): Promise<string>;
await apiV1();
Open in Playgroundimport { parse } from 'node:url';
// 'parse' is deprecated. Use the WHATWG URL API instead.
const url = parse('/foo');
Open in Playground/** @deprecated Use apiV2 instead. */
declare function apiV1(): Promise<string>;
declare function apiV2(): Promise<string>;
await apiV2();
Open in Playground// Modern Node.js API, uses `new URL()`
const url2 = new URL('/foo', 'http://www.example.com');
Open in PlaygroundOptions
This rule accepts the following options:
type Options = [
{
/** Type specifiers that can be allowed. */
allow?: (
| {
from: 'file';
name: [string, ...string[]] | string;
path?: string;
}
| {
from: 'lib';
name: [string, ...string[]] | string;
}
| {
from: 'package';
name: [string, ...string[]] | string;
package: string;
}
| string
)[];
},
];
const defaultOptions: Options = [{ allow: [] }];
allow
Type specifiers that can be allowed. Default: []
.
This option takes the shared TypeOrValueSpecifier
format.
Examples of code for this rule with:
{
"allow": [
{ "from": "file", "name": "apiV1" },
{ "from": "lib", "name": "escape" }
]
}
- ❌ Incorrect
- ✅ Correct
/** @deprecated */
declare function apiV2(): Promise<string>;
await apiV2();
// `unescape` has been deprecated since ES5.
unescape('...');
Open in Playgroundimport { Bar } from 'bar-lib';
/** @deprecated */
declare function apiV1(): Promise<string>;
await apiV1();
// `escape` has been deprecated since ES5.
escape('...');
Open in PlaygroundWhen Not To Use It
If portions of your project heavily use deprecated APIs and have no plan for moving to non-deprecated ones, you might want to disable this rule in those portions.
Related To
import/no-deprecated
andimport-x/no-deprecated
: Does not use type information, but does also support TomDoceslint-plugin-deprecation
(deprecation/deprecation
): Predecessor to this rule in a separate plugin
Type checked lint rules are more powerful than traditional lint rules, but also require configuring type checked linting.
See Troubleshooting > Linting with Type Information > Performance if you experience performance degradations after enabling type checked rules.