10.12.122 • Published 10 months ago

@womorg/et-magni-consequatur v10.12.122

Weekly downloads
-
License
MIT
Repository
github
Last release
10 months ago

@womorg/et-magni-consequatur

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('json-stringify');

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('json-stringify')

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('json-stringify');

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('json-stringify');

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 json-stringify

license

10.11.111

10 months ago

10.11.110

10 months ago

8.11.99

11 months ago

8.11.98

11 months ago

10.11.108

10 months ago

10.11.109

10 months ago

10.11.106

11 months ago

10.11.107

10 months ago

10.12.122

10 months ago

10.12.121

10 months ago

10.12.120

10 months ago

8.11.100

11 months ago

8.11.102

11 months ago

8.11.101

11 months ago

8.11.104

11 months ago

9.11.105

11 months ago

8.11.103

11 months ago

9.11.106

11 months ago

8.11.105

11 months ago

10.12.119

10 months ago

10.12.118

10 months ago

10.12.117

10 months ago

10.12.116

10 months ago

10.12.111

10 months ago

10.12.115

10 months ago

10.12.114

10 months ago

10.12.113

10 months ago

10.12.112

10 months ago

8.11.97

11 months ago

8.11.95

11 months ago

8.11.96

11 months ago

7.11.92

11 months ago

7.11.93

11 months ago

7.11.94

11 months ago

7.11.95

11 months ago

7.11.88

11 months ago

7.11.89

11 months ago

7.11.90

11 months ago

7.11.91

11 months ago

7.11.85

11 months ago

7.11.86

11 months ago

7.11.87

11 months ago

7.11.83

11 months ago

7.11.84

11 months ago

6.11.83

11 months ago

6.11.82

11 months ago

6.10.79

12 months ago

6.11.79

12 months ago

6.11.81

11 months ago

6.11.80

12 months ago

6.10.77

12 months ago

6.10.76

12 months ago

6.10.75

12 months ago

6.10.78

12 months ago

6.9.75

12 months ago

6.9.74

12 months ago

6.9.73

12 months ago

5.8.72

12 months ago

5.8.73

12 months ago

6.8.73

12 months ago

5.6.71

12 months ago

5.6.70

12 months ago

5.7.72

12 months ago

5.7.71

12 months ago

4.3.53

1 year ago

4.3.52

1 year ago

4.3.51

1 year ago

4.2.44

1 year ago

4.3.50

1 year ago

4.2.45

1 year ago

4.3.55

1 year ago

4.3.54

1 year ago

5.6.59

1 year ago

4.2.46

1 year ago

3.2.37

1 year ago

3.2.39

1 year ago

3.2.38

1 year ago

4.3.46

1 year ago

4.4.57

1 year ago

4.4.56

1 year ago

4.4.55

1 year ago

4.3.49

1 year ago

4.3.48

1 year ago

4.3.47

1 year ago

3.2.40

1 year ago

3.2.42

1 year ago

3.2.41

1 year ago

3.2.44

1 year ago

3.2.43

1 year ago

5.4.58

1 year ago

5.4.57

1 year ago

5.6.62

1 year ago

5.6.61

1 year ago

5.6.64

1 year ago

5.6.63

1 year ago

5.6.60

1 year ago

5.5.59

1 year ago

5.6.69

12 months ago

5.5.58

1 year ago

5.6.66

1 year ago

5.6.65

1 year ago

5.6.68

12 months ago

5.6.67

12 months ago

3.2.36

1 year ago

3.2.35

1 year ago

3.2.34

1 year ago

3.2.33

1 year ago

3.2.32

1 year ago

3.2.29

1 year ago

3.2.31

1 year ago

3.2.30

1 year ago

3.2.24

1 year ago

3.2.23

1 year ago

3.2.26

1 year ago

3.2.25

1 year ago

3.2.28

1 year ago

3.2.27

1 year ago

3.2.20

1 year ago

3.2.22

1 year ago

3.2.21

1 year ago

3.2.17

1 year ago

3.2.19

1 year ago

3.2.18

1 year ago

3.2.15

1 year ago

3.2.16

1 year ago

3.2.13

1 year ago

3.1.12

1 year ago

3.2.12

1 year ago

3.2.14

1 year ago

3.1.11

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.0.4

1 year ago

1.0.3

1 year ago

1.0.2

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago