UNPKG

eslint-config-ts-lib

Version:

ts-lib-scripts创建的ts库项目使用的ESLint配置

57 lines (38 loc) 1.95 kB
# @typescript-eslint/no-non-null-asserted-optional-chain > 来自 [plugin:@typescript-eslint/recommended](https://www.npmjs.com/package/@typescript-eslint/eslint-plugin) 的规则 # Disallows using a non-null assertion after an optional chain expression (`no-non-null-asserted-optional-chain`) ## Rule Details Optional chain expressions are designed to return `undefined` if the optional property is nullish. Using non-null assertions after an optional chain expression is wrong, and introduces a serious type safety hole into your code. Examples of **incorrect** code for this rule: ```ts /* eslint @typescript-eslint/no-non-null-asserted-optional-chain: "error" */ foo?.bar!; foo?.bar()!; // Prior to TS3.9, foo?.bar!.baz meant (foo?.bar).baz - i.e. the non-null assertion is applied to the entire chain so far. // For TS3.9 and greater, the non-null assertion is only applied to the property itself, so it's safe. // The following is incorrect code if you're using less than TS3.9 foo?.bar!.baz; foo?.bar!(); foo?.bar!().baz; ``` Examples of **correct** code for this rule: ```ts /* eslint @typescript-eslint/no-non-null-asserted-optional-chain: "error" */ foo?.bar; (foo?.bar).baz; foo?.bar(); foo?.bar(); foo?.bar().baz; // The following is correct code if you're using TS3.9 or greater foo?.bar!.baz; foo?.bar!(); foo?.bar!().baz; ``` ## When Not To Use It If you are not using TypeScript 3.7 (or greater), then you will not need to use this rule, as the operator is not supported. ## Further Reading - [TypeScript 3.7 Release Notes](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-3-7.html) - [Optional Chaining Proposal](https://github.com/tc39/proposal-optional-chaining/) ## 参考文档 - [@typescript-eslint/no-non-null-asserted-optional-chain 官方文档](https://github.com/typescript-eslint/typescript-eslint/blob/HEAD/packages/eslint-plugin/docs/rules/no-non-null-asserted-optional-chain.md)