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

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.
  • 默认值表达式在每次调用时执行(不是定义时),所以可安全使用函数调用或生成唯一值:id = Date.now()arr = [] 都没问题
  • 不能省略前面的参数来只设置后面的默认值:greet(undefined, 25) 才能触发 name 的默认值,不能写成 greet(, 25)
  • 与解构默认值共用时要注意顺序:先解析参数结构,再应用默认值

|| 写法对比:为什么别再用 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'
  • || 是布尔运算,用于“兜底”不严谨;默认参数是语言

    级机制,专为“未传参”设计
  • 如果真需要处理 null 或空字符串,应显式判断:name == null ? 'Guest' : name,而不是依赖默认参数

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

默认值表达式可以引用之前已声明的参数,甚至外层作用域变量,这在构造灵活 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) {
  // ...
}
  • 参数间引用必须按顺序:只能用左侧已声明的参数,不能跨过中间参数引用
  • 不能在默认值中引用尚未声明的参数,否则报 ReferenceError
  • 箭头函数同样支持,默认参数规则完全一致

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