10.12.122 • Published 12 months ago

@womorg/et-magni-consequatur v10.12.122

Weekly downloads
-
License
MIT
Repository
github
Last release
12 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

12 months ago

10.11.110

12 months ago

8.11.99

1 year ago

8.11.98

1 year ago

10.11.108

12 months ago

10.11.109

12 months ago

10.11.106

12 months ago

10.11.107

12 months ago

10.12.122

12 months ago

10.12.121

12 months ago

10.12.120

12 months ago

8.11.100

1 year ago

8.11.102

1 year ago

8.11.101

1 year ago

8.11.104

1 year ago

9.11.105

12 months ago

8.11.103

1 year ago

9.11.106

12 months ago

8.11.105

1 year ago

10.12.119

12 months ago

10.12.118

12 months ago

10.12.117

12 months ago

10.12.116

12 months ago

10.12.111

12 months ago

10.12.115

12 months ago

10.12.114

12 months ago

10.12.113

12 months ago

10.12.112

12 months ago

8.11.97

1 year ago

8.11.95

1 year ago

8.11.96

1 year ago

7.11.92

1 year ago

7.11.93

1 year ago

7.11.94

1 year ago

7.11.95

1 year ago

7.11.88

1 year ago

7.11.89

1 year ago

7.11.90

1 year ago

7.11.91

1 year ago

7.11.85

1 year ago

7.11.86

1 year ago

7.11.87

1 year ago

7.11.83

1 year ago

7.11.84

1 year ago

6.11.83

1 year ago

6.11.82

1 year ago

6.10.79

1 year ago

6.11.79

1 year ago

6.11.81

1 year ago

6.11.80

1 year ago

6.10.77

1 year ago

6.10.76

1 year ago

6.10.75

1 year ago

6.10.78

1 year ago

6.9.75

1 year ago

6.9.74

1 year ago

6.9.73

1 year ago

5.8.72

1 year ago

5.8.73

1 year ago

6.8.73

1 year ago

5.6.71

1 year ago

5.6.70

1 year ago

5.7.72

1 year ago

5.7.71

1 year 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

1 year ago

5.5.58

1 year ago

5.6.66

1 year ago

5.6.65

1 year ago

5.6.68

1 year ago

5.6.67

1 year 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