首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

no-useless-rename

--fix命令行上的选项可以自动修复一些被这条规则反映的问题。

ES2015允许重命名导入和导出语句中的引用以及解构赋值。这为程序员提供了一个简洁的语法,用于在重命名这些引用时执行这些操作:

代码语言:javascript
复制
import { foo as bar } from "baz";
export { foo as bar };
let { foo: bar } = baz;

使用这种语法,可以将引用重命名为相同的名称。这是一个完全冗余的操作,因为这与完全不重命名相同。例如,这个:

代码语言:javascript
复制
import { foo as foo } from "bar";
export { foo as foo };
let { foo: foo } = bar;

是相同的:

代码语言:javascript
复制
import { foo } from "bar";
export { foo };
let { foo } = bar;

规则细节

此规则不允许将导入、导出和解构分配重命名为相同的名称。

选项

此规则允许使用以下选项进行更细粒度的控制:

  • ignoreImport:设置为时true,此规则不检查导入
  • ignoreExport:设置为时true,此规则不检查导出
  • ignoreDestructuring:设置为时true,此规则不检查解构分配

默认情况下,所有选项都设置为false

代码语言:javascript
复制
"no-useless-rename": ["error", {
    "ignoreDestructuring": false,
    "ignoreImport": false,
    "ignoreExport": false
}]

默认情况下此规则的代码不正确的示例:

代码语言:javascript
复制
/*eslint no-useless-rename: "error"*/

import { foo as foo } from "bar";
export { foo as foo };
export { foo as foo } from "bar";
let { foo: foo } = bar;
let { 'foo': foo } = bar;
function foo({ bar: bar }) {}
({ foo: foo }) => {}

默认情况下此规则的正确代码示例:

代码语言:javascript
复制
/*eslint no-useless-rename: "error"*/

import * as foo from "foo";
import { foo } from "bar";
import { foo as bar } from "baz";

export { foo };
export { foo as bar };
export { foo as bar } from "foo";

let { foo } = bar;
let { foo: bar } = baz;
let { [foo]: foo } = bar;

function foo({ bar }) {}
function foo({ bar: baz }) {}

({ foo }) => {}
({ foo: bar }) => {}

此规则的正确代码示例{ ignoreImport: true }

代码语言:javascript
复制
/*eslint no-useless-rename: ["error", { ignoreImport: true }]*/

import { foo as foo } from "bar";

此规则的正确代码示例{ ignoreExport: true }

代码语言:javascript
复制
/*eslint no-useless-rename: ["error", { ignoreExport: true }]*/

export { foo as foo };
export { foo as foo } from "bar";

此规则的正确代码示例{ ignoreDestructuring: true }

代码语言:javascript
复制
/*eslint no-useless-rename: ["error", { ignoreDestructuring: true }]*/

let { foo: foo } = bar;
function foo({ bar: bar }) {}
({ foo: foo }) => {}

何时不使用它

如果您不关心冗余重命名导入、导出和解构赋值,则可以安全地禁用此规则。

兼容性

扫码关注腾讯云开发者

领取腾讯云代金券