Skip to content

Latest commit

 

History

History
27 lines (20 loc) · 960 Bytes

spread-merging-objects-includes-nil-values.md

File metadata and controls

27 lines (20 loc) · 960 Bytes

Spread Merging Objects Includes Nil Values

A handy way to merge two objects together with ES6 JavaScript syntax is to use the spread operator.

const combinedObj = { ...obj1, ...obj2 };

All the key-value pairs from each object are combined into a new object. For any overlapping keys, the last occurrence's value will take precedence.

That bit about precedence is true for nil values – null and undefined – as well.

const obj1 = { taco: 'bell', hello: 'world', list: [1,2,3] }
const obj2 = { burrito: 'house', hello: null, list: undefined }

const combinedObj = { ...obj1, ...obj2 }
//=> { taco: 'bell', hello: null, list: undefined, burrito: 'house' }

Notice that even though there are "actual" values for the hello and list keys in obj1, they are overridden by the null and undefined values in obj2.