Skip to content

defaults (Lodash 兼容性)

请使用 Object.assign() 代替

defaults 函数由于特殊处理 undefined 和从 Object.prototype 继承的属性的复杂逻辑而运行缓慢。

请改用更快、更现代的 Object.assign()

通过设置默认值来填充对象中的 undefined 属性。

typescript
const result = defaults(object, source);

参考

defaults(object, ...sources)

当您想为对象中的 undefined 属性或从 Object.prototype 继承的属性设置默认值时,请使用 defaults。您可以传递多个默认值对象,它们将按从左到右的顺序应用。

typescript
import { defaults } from 'es-toolkit/compat';

// 用默认值填充 undefined 属性
defaults({ a: 1 }, { a: 2, b: 2 }, { c: 3 });
// 返回值: { a: 1, b: 2, c: 3 }

// 只有 undefined 属性会用默认值填充
defaults({ a: undefined }, { a: 1 });
// 返回值: { a: 1 }

// null 值保持不变
defaults({ a: null }, { a: 1 });
// 返回值: { a: null }

如果属性已经有值,则不会用默认值覆盖。

typescript
import { defaults } from 'es-toolkit/compat';

defaults({ a: 1, b: 2 }, { b: 3 }, { c: 3 });
// 返回值: { a: 1, b: 2, c: 3 }

参数

  • object (any): 要设置默认值的目标对象。
  • ...sources (any[]): 提供默认值的源对象。

返回值

(any): 返回设置了默认值的对象。第一个参数 object 会被修改。

采用 MIT 许可证发布。