Gathering detailed insights and metrics for @omegion1npm/repellendus-aut-sit
Gathering detailed insights and metrics for @omegion1npm/repellendus-aut-sit
npm install @omegion1npm/repellendus-aut-sit
Typescript
Module System
Node Version
NPM Version
51.2
Supply Chain
48.1
Quality
75.7
Maintenance
100
Vulnerability
99.6
License
JavaScript (100%)
Total Downloads
103
Last Day
1
Last Week
1
Last Month
5
Last Year
103
2,179 Commits
1 Branches
1 Contributors
Latest Version
1.0.0
Package Id
@omegion1npm/repellendus-aut-sit@1.0.0
Unpacked Size
18.17 kB
Size
7.00 kB
File Count
10
NPM Version
10.5.0
Node Version
20.12.2
Publised On
25 Apr 2024
Cumulative downloads
Total Downloads
Last day
0%
1
Compared to previous day
Last week
0%
1
Compared to previous week
Last month
400%
5
Compared to previous month
Last year
0%
103
Compared to previous year
27
deterministic version of JSON.stringify()
so you can get a consistent hash from stringified results
You can also pass in a custom comparison function.
1const stringify = require('@omegion1npm/repellendus-aut-sit'); 2 3const obj = { c: 8, b: [{ z: 6, y: 5, x: 4 }, 7], a: 3 }; 4 5console.log(stringify(obj));
output:
{"a":3,"b":[{"x":4,"y":5,"z":6},7],"c":8}
1const stringify = require('@omegion1npm/repellendus-aut-sit')
Return a deterministic stringified string str
from the object obj
.
If opts
is given, you can supply an opts.cmp
to have a custom comparison function for object keys.
Your function opts.cmp
is called with these parameters:
1opts.cmp({ key: akey, value: avalue }, { key: bkey, value: bvalue }, { get(key): value })
For example, to sort on the object key names in reverse order you could write:
1const stringify = require('@omegion1npm/repellendus-aut-sit'); 2 3const obj = { c: 8, b: [{ z: 6, y: 5, x: 4 },7], a: 3 }; 4 5const s = stringify(obj, function (a, b) { 6 return b.key.localeCompare(a.key); 7}); 8 9console.log(s);
which results in the output string:
1{"c":8,"b":[{"z":6,"y":5,"x":4},7],"a":3}
Or if you wanted to sort on the object values in reverse order, you could write:
1const stringify = require('@omegion1npm/repellendus-aut-sit'); 2 3const obj = { d: 6, c: 5, b: [{ z: 3, y: 2, x: 1 }, 9], a: 10 }; 4 5const s = stringify(obj, function (a, b) { 6 return a.value < b.value ? 1 : -1; 7}); 8 9console.log(s);
which outputs:
1{"d":6,"c":5,"b":[{"z":3,"y":2,"x":1},9],"a":10}
An additional param get(key)
returns the value of the key from the object being currently compared.
If you specify opts.space
, it will indent the output for pretty-printing.
Valid values are strings (e.g. {space: \t}
) or a number of spaces
({space: 3}
).
For example:
1const obj = { b: 1, a: { foo: 'bar', and: [1, 2, 3] } }; 2 3const s = stringify(obj, { space: ' ' }); 4 5console.log(s);
which outputs:
{
"a": {
"and": [
1,
2,
3
],
"foo": "bar"
},
"b": 1
}
The replacer parameter is a function opts.replacer(key, value)
that behaves the same as the replacer
from the core JSON object.
With npm do:
npm install @omegion1npm/repellendus-aut-sit
MIT
No vulnerabilities found.
No security vulnerabilities found.