贝利信息

javascript默认参数怎么设置_有什么好处【教程】

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

JavaScript 默认参数直接在函数声明时用 = 赋值即可,不需要靠 ||typeof 判断,ES6 原生支持,写法简洁且语义清晰。

函数定义时直接写 param = defaultValue

这是最常用也最安全的写法。默认值只在参数为 undefined 时生效,null0false'' 都会保留原值。

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.

|| 写法对比:为什么别再用 name || 'Guest'

老式写法 name = name || 'Guest' 看似简单,但会把所有 falsy 值(0false''nullundefined)一并覆盖,导致业务逻辑出错。

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'

默认参数能访问前面的参数或闭包变量

默认值表达式可以引用之前已声明的参

数,甚至外层作用域变量,这在构造灵活 API 时很有用。

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) {
  // ...
}

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