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,而不是依赖默认参数默认值表达式可以引用之前已声明的参

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
真正容易被忽略的是:默认参数的求值时机和作用域链——它不是“静态默认”,而是每次调用都重新计算,且能捕获当前作用域,这点让工厂函数、带状态的默认值成为可能。别把它当成简单的语法糖,它是函数行为的一部分。