# no-catch-shadow

此规则在 ESLint v5.1.0 中已弃用。

在 IE 8 和更早版本中,如果该变量与 catch 子句参数同名,则 catch 子句参数可以覆盖外部范围内的变量的值。

var err = "x";

try {
    throw "problem";
} catch (err) {

}

console.log(err)    // err is 'problem', not 'x'

# 规则详情

此规则旨在防止程序中的意外行为,这些行为可能由 IE 8 及更早版本中的错误引起,其中 catch 子句参数可能会泄漏到外部范围。每当遇到与外部作用域中的变量同名的 catch 子句参数时,此规则都会发出警告。

此规则的错误代码示例:

/*eslint no-catch-shadow: "error"*/

var err = "x";

try {
    throw "problem";
} catch (err) {

}

function err() {
    // ...
};

try {
    throw "problem";
} catch (err) {

}

此规则的正确代码示例:

/*eslint no-catch-shadow: "error"*/

var err = "x";

try {
    throw "problem";
} catch (e) {

}

function err() {
    // ...
};

try {
    throw "problem";
} catch (e) {

}

# 何时不使用

如果您不需要支持 IE 8 及更早版本,则应关闭此规则。

Last Updated: 5/13/2023, 8:55:38 PM