Suggest using the spread operator instead of .apply(). (prefer-spread)

Before ES2015, one must use Function.prototype.apply() to call variadic functions.

var args = [1, 2, 3, 4];
Math.max.apply(Math, args);

In ES2015, one can use the spread operator to call variadic functions.

/*eslint-env es6*/

var args = [1, 2, 3, 4];

Rule Details

This rule is aimed to flag usage of Function.prototype.apply() that can be replaced with the spread operator.

The following patterns are considered problems:

/*eslint prefer-spread: "error"*/

foo.apply(undefined, args);

foo.apply(null, args);, args);

The following patterns are not considered problems:

/*eslint prefer-spread: "error"*/

// The `this` binding is different.
foo.apply(obj, args);, args);, args);

// The argument list is not variadic.
// Those are warned by the `no-useless-call` rule.
foo.apply(undefined, [1, 2, 3]);
foo.apply(null, [1, 2, 3]);, [1, 2, 3]);

Known limitations:

This rule analyzes code statically to check whether or not the this argument is changed. So if the this argument is computed in a dynamic expression, this rule cannot detect a violation.

/*eslint prefer-spread: "error"*/

// This warns.
a[i++].foo.apply(a[i++], args);

// This does not warn.
a[++i].foo.apply(a[i], args);

When Not To Use It

This rule should not be used in ES3/5 environments.

In ES2015 (ES6) or later, if you don’t want to be notified about Function.prototype.apply() callings, you can safely disable this rule.


This rule was introduced in ESLint 1.0.0-rc-1.