noThenProperty
诊断类别:lint/suspicious/noThenProperty
¥Diagnostic Category: lint/suspicious/noThenProperty
自从:v1.5.0
¥Since: v1.5.0
来源:
¥Sources:
-
与以下相同:
unicorn/no-thenable
¥Same as:
unicorn/no-thenable
禁止 then
属性。
¥Disallow then
property.
当将具有 then
方法的对象(thenable 对象)与 await 表达式或动态导入组合时,需要小心谨慎。这些语法将对象的 then 方法解释为用于解决或拒绝承诺,这可能会导致意外行为或错误。
¥When combining objects with a then
method (thenable objects) with await expressions or dynamic imports, caution is necessary.
These syntaxes interpret the object’s then method as intended for the resolution or rejection of a promise, which can lead to unexpected behavior or errors.
¥Examples
¥Invalid
code-block.js:1:9 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not export then.
> 1 │ export {then};
│ ^^^^
2 │
code-block.js:2:5 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not add then to an object.
1 │ const foo = {
> 2 │ then() {}
│ ^^^^
3 │ };
4 │
code-block.js:2:9 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not add then to an object.
1 │ const foo = {
> 2 │ get then() {}
│ ^^^^
3 │ };
4 │
code-block.js:2:8 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not add then to an object.
1 │ const foo = {
> 2 │ get then() {}
│ ^^^^
3 │ };
4 │
code-block.js:1:1 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not add then to an object.
> 1 │ foo.then = function () {}
│ ^^^^^^^^
2 │
code-block.js:2:5 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not add then to a class.
1 │ class Foo {
> 2 │ then() {}
│ ^^^^
3 │ }
4 │
code-block.js:2:12 lint/suspicious/noThenProperty ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ Do not add then to a class.
1 │ class Foo {
> 2 │ static then() {}
│ ^^^^
3 │ }
4 │
¥Valid
¥Related links