1.2.14 • Published 3 days ago

@dramaorg/impedit-voluptatibus-officia v1.2.14

Weekly downloads
-
License
MIT
Repository
github
Last release
3 days ago

@dramaorg/impedit-voluptatibus-officia Version Badge

github actions coverage License Downloads

npm badge

deterministic version of JSON.stringify() so you can get a consistent hash from stringified results

You can also pass in a custom comparison function.

example

const stringify = require('@dramaorg/impedit-voluptatibus-officia');

const obj = { c: 8, b: [{ z: 6, y: 5, x: 4 }, 7], a: 3 };

console.log(stringify(obj));

output:

{"a":3,"b":[{"x":4,"y":5,"z":6},7],"c":8}

methods

const stringify = require('@dramaorg/impedit-voluptatibus-officia')

const str = stringify(obj, opts)

Return a deterministic stringified string str from the object obj.

options

cmp

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:

opts.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:

const stringify = require('@dramaorg/impedit-voluptatibus-officia');

const obj = { c: 8, b: [{ z: 6, y: 5, x: 4 },7], a: 3 };

const s = stringify(obj, function (a, b) {
	return b.key.localeCompare(a.key);
});

console.log(s);

which results in the output string:

{"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:

const stringify = require('@dramaorg/impedit-voluptatibus-officia');

const obj = { d: 6, c: 5, b: [{ z: 3, y: 2, x: 1 }, 9], a: 10 };

const s = stringify(obj, function (a, b) {
	return a.value < b.value ? 1 : -1;
});

console.log(s);

which outputs:

{"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.

space

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:

const obj = { b: 1, a: { foo: 'bar', and: [1, 2, 3] } };

const s = stringify(obj, { space: '  ' });

console.log(s);

which outputs:

{
  "a": {
    "and": [
      1,
      2,
      3
    ],
    "foo": "bar"
  },
  "b": 1
}

replacer

The replacer parameter is a function opts.replacer(key, value) that behaves the same as the replacer from the core JSON object.

install

With npm do:

npm install @dramaorg/impedit-voluptatibus-officia

license

MIT

1.2.14

3 days ago

1.2.12

5 days ago

1.2.13

4 days ago

1.2.10

7 days ago

1.2.11

6 days ago

1.1.10

8 days ago

1.1.9

9 days ago

1.1.8

10 days ago

1.1.7

11 days ago

1.1.6

12 days ago

1.1.5

13 days ago

1.0.5

14 days ago

1.0.4

15 days ago

1.0.3

16 days ago

1.0.2

17 days ago

1.0.1

18 days ago

1.0.0

18 days ago