JavaScript默认参数仅在参数为undefined时生效,null、0、false、''等falsy值均保留原值;支持表达式每次调用重新求值,可引用前序参数及闭包变量,语义精准且安全。

JavaScript 默认参数直接在函数声明时用 = 赋值即可,不需要靠 || 或 typeof 判断,ES6 原生支持,写法简洁且语义清晰。
函数定义时直接写 param = defaultValue
这是最常用也最安全的写法。默认值只在参数为 undefined 时生效,null、0、false、'' 都会保留原值。
function greet(name = 'Guest', age = 18) {
console.log(`Hello ${name}, you are ${age} years old.`);
}
greet(); // Hello Guest, you are 18 years old.
greet('Alice'); // Hello Alice, you are 18 years old.
greet('Bob', 0); // Hello Bob, you are 0 years old. ← 注意:0 不触发默认值
greet('Carl', null); // Hello Carl, you are null years old.
- 默认值表达式在每次调用时执行(不是定义时),所以可安全使用函数调用或生成唯一值:
id = Date.now()、arr = []都没问题 - 不能省略前面的参数来只设置后面的默认值:
greet(undefined, 25)才能触发name的默认值,不能写成greet(, 25) - 与解构默认值共用时要注意顺序:先解析参数结构,再应用默认值
和 || 写法对比:为什么别再用 name || 'Guest'
老式写法 name = name || 'Guest' 看似简单,但会把所有 falsy 值(0、false、''、null、undefined)一并覆盖,导致业务逻辑出错。
function badGreet(name) {
name = name || 'Guest'; // ❌ 把空字符串和 0 也替换了
return `Hi ${name}`;
}
badGreet(''); // 'Hi Guest' —— 但你可能想保留空用户名
badGreet(0); // 'Hi Guest' —— 但 0 是合法年龄或 ID
function goodGreet(name = 'Guest') { // ✅ 只对 undefined 生效
return `Hi ${name}`;
}
goodGreet(''); // 'Hi '
goodGreet(0); // 'Hi 0'
-
||是布尔运算,用于“兜底”不严谨;默认参数是语言级机制,专为“未传参”设计 - 如果真需要处理
null或空字符串,应显式判断:name == null ? 'Guest' : name,而不是依赖默认参数
默认参数能访问前面的参数或闭包变量
默认值表达式可以引用之前已声明的参数,甚至外层作用域变量,这在构造灵活 API 时很有用。
立即学习“Java免费学习笔记(深入)”;
function createConfig(baseURL, endpoint = baseURL + '/api', timeout = 5000) {
return { baseURL, endpoint, timeout };
}
createConfig('https://api.example.com');
// → { baseURL: 'https://api.example.com', endpoint: 'https://api.example.com/api', timeout: 5000 }
const DEFAULT_TIMEOUT = 3000;
function request(url, timeout = DEFAULT_TIMEOUT) {
// ...
}
- 参数间引用必须按顺序:只能用左侧已声明的参数,不能跨过中间参数引用
- 不能在默认值中引用尚未声明的参数,否则报
ReferenceError - 箭头函数同样支持,默认参数规则完全一致
真正容易被忽略的是:默认参数的求值时机和作用域链——它不是“静态默认”,而是每次调用都重新计算,且能捕获当前作用域,这点让工厂函数、带状态的默认值成为可能。别把它当成简单的语法糖,它是函数行为的一部分。











