no-object-as-default-parameter
March 27, 2026 ยท View on GitHub
๐ Disallow the use of objects as default parameters.
๐ผ This rule is enabled in the following configs: โ
recommended, โ๏ธ unopinionated.
Default parameters should not be passed to a function through an object literal. The foo = {a: false} parameter works fine if only used with one option. As soon as additional options are added, you risk replacing the whole foo = {a: false, b: true} object when passing only one option: {a: true}. For this reason, object destructuring should be used instead.
Examples
// โ
function foo({a} = {a: false}) {}
// โ
function foo(options) {
const {a} = {a: false, ...options};
}
// โ
const abc = (foo = {a: false, b: 123}) => {};
// โ
const foo = ({a = false, b = 123}) => {};
// โ
const abc = (foo = {}) => {};
// โ
const abc = (foo = false) => {};