eslint/no-param-reassign 限制
它的作用
禁止重新赋值函数参数,或可选地禁止重新赋值其属性。
为什么这是不好的?
重新赋值参数可能导致意外行为,尤其是在依赖传入函数的原始参数时。修改参数属性同样可能令人意外,且更难理解。
示例
javascript
function foo(bar) {
bar = 1;
}
function baz(qux) {
qux.prop = 2; // 当启用 `props` 选项时
}配置
此规则接受一个配置对象,包含以下属性:
ignorePropertyModificationsFor
type: string[]
default: []
一个参数名称数组,其属性修改将被忽略。
ignorePropertyModificationsForRegex
type: string[]
一个正则表达式模式数组(以字符串形式),用于指定应忽略其属性修改的参数名称。 请注意,这使用的是 Rust 正则语法,因此可能不支持所有 JavaScript 正则表达式功能。
props
type: boolean
default: false
当为 true 时,也检查对参数属性的修改。
如何使用
要通过配置文件或 CLI 启用此规则,可以使用:
json
{
"rules": {
"no-param-reassign": "error"
}
}bash
oxlint --deny no-param-reassign