flat-obj

A tiny (173B) utility to flatten an object with customizable glue
This module squashes a nested object (including its internal Arrays) so that the output is a flat object – AKA, it has a single level of depth. By default, the _ character is used to glue/join layers' keys together. This is customizable, of course.
Finally, any keys with nullish values (null and undefined) are not included in the return object.
Install
$ npm install --save flat-obj
Usage
import flatObj from 'flat-obj';
flatObj({
a: 'hi',
b: {
a: null,
b: '',
d: 'hello',
e: {
a: 'yo',
b: undefined,
c: 'sup',
d: 0
}
},
c: 'world'
});
Note: null and undefined values are purged.
API
flatObj(input, [glue])
Returns: Object
Returns a new object with a single level of depth.
input
Type: Object
The object to flatten.
glue
Type: String
Default: _
A string used to join parent key names to nested child key names.
const foo = { bar: 123 };
flatObj({ foo });
flatObj({ foo }, '.');
Benchmarks
Running on Node.js v10.13.0
Validation:
✔ flat
✔ flatten-object
✔ flat-obj@1.x
✔ flat-obj
Benchmark:
flat x 187,778 ops/sec ±1.27% (87 runs sampled)
flatten-object x 191,514 ops/sec ±0.26% (93 runs sampled)
flat-obj@1.x x 268,060 ops/sec ±1.21% (94 runs sampled)
flat-obj x 622,744 ops/sec ±0.33% (92 runs sampled)
License
MIT © Luke Edwards