2.2.22 • Published 1 year ago
@juigorg/alias-culpa-alias v2.2.22
@juigorg/alias-culpa-alias
Safely flatten a nested JavaScript object.
Installation
$ npm i @juigorg/alias-culpa-alias
Methods
flatten(obj, delimiter)
Flattens an object to one level deep. Optionally takes a custom delimiter
, otherwise uses .
by default. Circular references within the object will be replaced with [Circular]
.
const { flatten } = require('@juigorg/alias-culpa-alias')
const original = {
a: {
b: {
c: [{
val: 'one'
}, {
val: 'two'
}],
d: 'three'
},
e: 'four',
}
}
original.a.b.f = original.a.b
original.a.b.c.push(original.a)
const flat = flatten(original)
/*
{
'a.b.c.0.val': 'one',
'a.b.c.1.val': 'two',
'a.b.c.2': '[Circular]',
'a.b.d': 'three',
'a.e': 'four',
'a.b.f': '[Circular]'
}
*/
const underscoreFlat = flatten(original, '_')
/*
{
'a_b_c_0_val': 'one',
'a_b_c_1_val': 'two',
'a_b_c_2': '[Circular]',
'a_b_d': 'three',
'a_e': 'four',
'a_b_f': '[Circular]'
}
*/
unflatten(obj, delimiter)
Unflattens an object back to its original nested form. Optionally takes a custom delimiter
, otherwise uses .
by default. Circular references denoted by [Circular]
are treated as Strings.
const { unflatten } = require('@juigorg/alias-culpa-alias')
const original = {
'a.b.c.0.val': 'one',
'a.b.c.1.val': 'two',
'a.b.c.2': '[Circular]',
'a.b.d': 'three',
'a.e': 'four',
'a.b.f': '[Circular]'
}
const unflat = unflatten(original)
/*{
a:{
b:{
c:[
{
val:'one'
},
{
val:'two'
},
'[Circular]'
],
d:'three',
f:'[Circular]'
},
e:'four'
}
}*/
2.1.18
1 year ago
2.1.19
1 year ago
2.1.21
1 year ago
2.1.22
1 year ago
2.1.20
1 year ago
2.1.17
1 year ago
2.2.22
1 year ago
2.1.16
1 year ago
2.1.14
1 year ago
2.1.15
1 year ago
2.1.12
1 year ago
2.1.13
1 year ago
2.1.11
1 year ago
2.1.10
1 year ago
2.1.9
1 year ago
2.1.8
1 year ago
2.1.7
1 year ago
2.1.6
1 year ago
2.1.5
1 year ago
2.1.4
1 year ago
1.1.4
1 year ago
1.1.3
1 year ago
1.1.2
1 year ago
1.0.2
1 year ago
1.0.1
1 year ago
1.0.0
1 year ago