All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sonar.l10n.javascript.rules.javascript.S3513.html Maven / Gradle / Ivy

There is a newer version: 10.17.0.28100
Show newest version

Why is this an issue?

The magic of JavaScript is that you can pass arguments to functions that don’t declare parameters, and on the other side, you can use those passed-in arguments inside the no-args function.

But just because you can, that does’t mean you should. The expectation and use of arguments inside functions that don’t explicitly declare them is confusing to callers. No one should ever have to read and fully understand a function to be able to use it competently.

If you don’t want to name arguments explicitly, use the ... syntax to specify that an a variable number of arguments is expected. Then inside the function, you’ll be dealing with a first-class array, rather than an array-like structure.

Noncompliant code example

function concatenate() {
  let args = Array.prototype.slice.call(arguments);  // Noncompliant
  return args.join(', ');
}

function doSomething(isTrue) {
  var args = Array.prototype.slice.call(arguments, 1); // Noncompliant
  if (!isTrue) {
    for (var arg of args) {
      ...
    }
  }
}

Compliant solution

function concatenate(...args) {
  return args.join(', ');
}

function doSomething(isTrue, ...values) {
  if (!isTrue) {
    for (var value of values) {
      ...
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy