跳到主要内容

avoid_redundant_argument_values

稳定版
修复可用

避免多余的参数值。

详情

#

不要传递与相应参数的默认值匹配的参数。

请注意,方法重写可以更改参数的默认值,因此一个参数可能等于一个默认值,但不等于另一个默认值。例如,考虑两个类 AB,其中 BA 的子类,并且 B 重写了在 A 上声明的方法,并且该方法在 A 的声明中有一个默认值,而在 B 的声明中有不同的默认值。如果被调用方法的目标的静态类型是 B,并且 B 的默认值与参数匹配,则可以省略该参数(并且如果参数值不同,则不会报告 lint)。但是,如果被调用方法的目标的静态类型是 A,则可能会报告 lint,但我们无法静态地知道调用了哪个方法,因此报告的 lint 可能是误报。这种情况可以使用类似 // ignore: avoid_redundant_argument_values 的注释内联忽略。

错误

dart
void f({bool valWithDefault = true, bool? val}) {
  ...
}

void main() {
  f(valWithDefault: true);
}

正确

dart
void f({bool valWithDefault = true, bool? val}) {
  ...
}

void main() {
  f(valWithDefault: false);
  f();
}

启用

#

要启用 avoid_redundant_argument_values 规则,请在您的 analysis_options.yaml 文件中的 linter > rules 下添加 avoid_redundant_argument_values

analysis_options.yaml
yaml
linter:
  rules:
    - avoid_redundant_argument_values

如果您改为使用 YAML 映射语法来配置 linter 规则,请在 linter > rules 下添加 avoid_redundant_argument_values: true

analysis_options.yaml
yaml
linter:
  rules:
    avoid_redundant_argument_values: true