Top Related Projects
Ace (Ajax.org Cloud9 Editor)
Diff & patch JavaScript objects
Diff Match Patch is a high-performance library in multiple languages that manipulates plain text.
A javascript text differencing implementation.
Javascript utility for calculating deep difference, capturing changes, and applying changes across objects; for nodejs and the browser.
Quick Overview
json-diff is a JavaScript library for comparing JSON objects and generating human-readable diffs. It provides a simple way to identify differences between two JSON structures, making it useful for debugging, testing, and data comparison tasks.
Pros
- Easy to use with a straightforward API
- Supports custom formatting options for diff output
- Can handle complex nested JSON structures
- Lightweight with no external dependencies
Cons
- Limited customization options for diff algorithm
- Not actively maintained (last update was in 2019)
- Lacks advanced features like patch generation or merging
- May not perform well with extremely large JSON objects
Code Examples
Comparing two JSON objects:
const jsonDiff = require('json-diff');
const obj1 = { a: 1, b: 2, c: { d: 3 } };
const obj2 = { a: 1, b: 3, c: { d: 4 } };
console.log(jsonDiff.diffString(obj1, obj2));
Customizing diff output:
const jsonDiff = require('json-diff');
const obj1 = { a: 1, b: 2 };
const obj2 = { a: 1, c: 3 };
const options = {
color: false,
keysOnly: true
};
console.log(jsonDiff.diffString(obj1, obj2, options));
Checking if two objects are equal:
const jsonDiff = require('json-diff');
const obj1 = { a: 1, b: [2, 3] };
const obj2 = { a: 1, b: [2, 3] };
console.log(jsonDiff.diff(obj1, obj2) === undefined);
Getting Started
To use json-diff in your project, follow these steps:
-
Install the library using npm:
npm install json-diff
-
Import the library in your JavaScript file:
const jsonDiff = require('json-diff');
-
Use the
diff
ordiffString
functions to compare JSON objects:const obj1 = { a: 1, b: 2 }; const obj2 = { a: 1, c: 3 }; console.log(jsonDiff.diffString(obj1, obj2));
That's it! You can now start comparing JSON objects in your project.
Competitor Comparisons
Ace (Ajax.org Cloud9 Editor)
Pros of Ace
- Comprehensive code editor with syntax highlighting, auto-completion, and more
- Supports a wide range of programming languages and file formats
- Highly customizable and extensible with plugins and themes
Cons of Ace
- Larger file size and more complex implementation
- May be overkill for simple JSON comparison tasks
- Steeper learning curve for basic usage
Code Comparison
json-diff:
var diff = jsonDiff.diff(obj1, obj2);
console.log(JSON.stringify(diff, null, 2));
Ace:
var editor = ace.edit("editor");
editor.setTheme("ace/theme/monokai");
editor.session.setMode("ace/mode/javascript");
Summary
json-diff is a lightweight library specifically designed for comparing JSON objects, while Ace is a full-featured code editor. json-diff is more suitable for quick JSON comparisons, whereas Ace offers a complete editing environment with advanced features.
json-diff is easier to integrate for simple JSON diff tasks, but Ace provides a more robust solution for code editing and visualization across multiple languages. The choice between the two depends on the specific requirements of your project and the level of functionality needed.
Diff & patch JavaScript objects
Pros of jsondiffpatch
- More comprehensive and feature-rich, offering advanced diffing and patching capabilities
- Supports custom equality checks and object hash functions for fine-grained control
- Provides visual diff rendering options for HTML and console output
Cons of jsondiffpatch
- Larger library size and potentially more complex to integrate
- May have a steeper learning curve due to its extensive feature set
- Performance might be slower for simple diff operations compared to json-diff
Code Comparison
jsondiffpatch:
var jsondiffpatch = require('jsondiffpatch');
var delta = jsondiffpatch.diff(obj1, obj2);
var patched = jsondiffpatch.patch(obj1, delta);
json-diff:
var jsonDiff = require('json-diff');
var diff = jsonDiff.diff(obj1, obj2);
console.log(jsonDiff.diffString(obj1, obj2));
Summary
jsondiffpatch offers a more robust and feature-rich solution for JSON diffing and patching, with advanced capabilities like custom equality checks and visual diff rendering. However, it may be overkill for simpler use cases and could have a performance impact on basic operations. json-diff, on the other hand, provides a more straightforward and lightweight approach, which may be sufficient for basic diffing needs but lacks some of the advanced features found in jsondiffpatch.
Diff Match Patch is a high-performance library in multiple languages that manipulates plain text.
Pros of diff-match-patch
- More versatile, supporting text diffing beyond just JSON
- Offers advanced features like fuzzy matching and patch application
- Well-maintained by Google with extensive documentation
Cons of diff-match-patch
- Not specifically optimized for JSON comparison
- May require additional setup for JSON-specific use cases
- Potentially more complex to use for simple JSON diff tasks
Code Comparison
json-diff:
var result = jsondiffpatch.diff(obj1, obj2);
console.log(jsondiffpatch.formatters.console.format(result));
diff-match-patch:
var dmp = new diff_match_patch();
var diff = dmp.diff_main(text1, text2);
dmp.diff_cleanupSemantic(diff);
console.log(diff);
Key Differences
- json-diff is specifically designed for JSON comparison, making it more straightforward for JSON-related tasks
- diff-match-patch offers a broader range of text diffing capabilities, suitable for various file types
- json-diff provides a more visually appealing output for JSON differences
- diff-match-patch offers additional features like fuzzy matching and patch merging
Use Case Recommendations
- Choose json-diff for quick and easy JSON comparison tasks
- Opt for diff-match-patch when dealing with various text formats or requiring advanced diffing features
A javascript text differencing implementation.
Pros of jsdiff
- More versatile, supporting diffing of various data types (text, JSON, arrays)
- Actively maintained with regular updates and a larger community
- Offers more advanced features like patch generation and application
Cons of jsdiff
- Larger library size, which may impact performance for simpler use cases
- Steeper learning curve due to more complex API and features
- May be overkill for projects only requiring JSON diffing
Code Comparison
json-diff:
var diff = jsonDiff.diff(obj1, obj2);
console.log(JSON.stringify(diff, null, 2));
jsdiff:
var diff = Diff.diffJson(obj1, obj2);
diff.forEach(function(part) {
console.log(part.value);
});
Summary
json-diff is a lightweight, specialized tool for JSON diffing, while jsdiff is a more comprehensive diffing library. json-diff is simpler to use for JSON-specific tasks, but jsdiff offers greater flexibility and features for various diffing needs. The choice between them depends on project requirements, with json-diff being suitable for quick JSON comparisons and jsdiff for more complex diffing scenarios across different data types.
Javascript utility for calculating deep difference, capturing changes, and applying changes across objects; for nodejs and the browser.
Pros of diff
- More comprehensive diffing capabilities, supporting various data types beyond JSON
- Actively maintained with recent updates and contributions
- Provides a more flexible API for customizing diff behavior
Cons of diff
- Larger package size and potentially more complex to use for simple JSON diffing
- May have a steeper learning curve for basic use cases
- Less focused on JSON-specific optimizations
Code Comparison
json-diff:
var diff = jsonDiff.diff(obj1, obj2);
console.log(JSON.stringify(diff, null, 2));
diff:
var diff = DeepDiff.diff(obj1, obj2);
console.log(JSON.stringify(diff, null, 2));
Both libraries offer similar basic usage for diffing objects, but diff provides more advanced options for customization:
var diff = DeepDiff.diff(obj1, obj2, function(path, key) {
return key[0] === '_';
});
This example demonstrates diff's ability to use a custom filter function during the diffing process, allowing for more fine-grained control over what is compared.
While json-diff is more focused on JSON-specific diffing with a simpler API, diff offers a broader range of features for comparing various data structures. The choice between the two depends on the specific requirements of your project and the complexity of the data you need to compare.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
JSON structural diff
Does exactly what you think it does:
Installation
npm install -g json-diff
Contribution policy
-
This project is maintained thanks to your contributions! Please send pull requests.
-
I will merge any pull request that adds something useful, does not break existing things, has reasonable code quality and provides/updates tests where appropriate.
-
Anyone who gets a significant pull request merged gets commit access to the repository.
Usage
Simple:
json-diff a.json b.json
Detailed:
% json-diff --help
Usage: json-diff [-vCjfonskKp] first.json second.json
Arguments:
<first.json> Old file
<second.json> New file
General options:
-v, --verbose Output progress info
-C, --[no-]color Colored output
-j, --raw-json Display raw JSON encoding of the diff
-f, --full Include the equal sections of the document, not just the deltas
--max-elisions COUNT Max number of ...s to show in a row in "deltas" mode (before
collapsing them)
-o, --output-keys KEYS Always print this comma separated keys, with their value, if they are
part of an object with any diff
-x, --exclude-keys KEYS Exclude these comma separated keys from comparison on both files
-n, --output-new-only Output only the updated and new key/value pairs (without marking them as
such). If you need only the diffs from the old file, just exchange the
first and second json.
-s, --sort Sort primitive values in arrays before comparing
-k, --keys-only Compare only the keys, ignore the differences in values
-K, --keep-unchanged-values Instead of omitting values that are equal, output them as they are
-p, --precision DECIMALS Round all floating point numbers to this number of decimal places prior
to comparison
-h, --help Display this usage information
In javascript (ES5):
var jsonDiff = require('json-diff');
console.log(jsonDiff.diffString({ foo: 'bar' }, { foo: 'baz' }));
// Output:
// {
// - foo: "bar"
// + foo: "baz"
// }
// As above, but without console colors
console.log(jsonDiff.diffString({ foo: 'bar' }, { foo: 'baz' }, { color: false }));
// Raw output:
console.log(jsonDiff.diff({ foo: 'bar', b: 3 }, { foo: 'baz', b: 3 }));
// Output:
// { foo: { __old: 'bar', __new: 'baz' } }
// Passing in the "full" option:
console.log(jsonDiff.diff({ foo: 'bar', b: 3 }, { foo: 'baz', b: 3 }, { full: true }));
// Output:
// { foo: { __old: 'bar', __new: 'baz' }, b: 3 }
In javascript (ES6+):
import { diffString, diff } from 'json-diff';
console.log(diffString({ foo: 'bar' }, { foo: 'baz' }));
console.log(diff({ foo: 'bar' }, { foo: 'baz' }));
Features
- colorized, diff-like output
- fuzzy matching of modified array elements (when array elements are object hierarchies)
- "keysOnly" option to compare only the json structure (keys), ignoring the values
- "full" option to output the entire json tree, not just the deltas
- "outputKeys" option to always output the given keys for an object that has differences
- reasonable test coverage (far from 100%, though)
Output Language in Raw-json mode ("full" mode)
ARRAYS
Unless two arrays are equal, all array elements are transformed into 2-tuple arrays:
- The first element is a one character string denoting the equality ('+', '-', '~', ' ')
- The second element is the old (-), new (+), altered sub-object (~), or unchanged (' ') value
json-diff.js --full --raw-json <(echo '[1,7,3]') <(echo '[1,2,3]')
[ [ " ", 1 ], [ "-", 7 ], [ "+", 2 ], [ " ", 3 ] ]
json-diff.js --full --raw-json <(echo '[1,["a","b"],4]') <(echo '[1,["a","c"],4]')
[ [ " ", 1 ], [ "~", [ [ " ", "a" ], [ "-", "b" ], [ "+", "c" ] ] ], [ " ", 4 ] ]
- If two arrays are equal, they are left as is.
OBJECTS
Object property values:
- If equal, they are left as is
- Unequal scalar values are replaced by an object containing the old and new value:
json-diff.js --full --raw-json <(echo '{"a":4}') <(echo '{"a":5}')
{ "a": { "__old": 4, "__new": 5 } }
- Unequal arrays and objects are replaced by their diff:
json-diff.js --full --raw-json <(echo '{"a":[4,5]}') <(echo '{"a":[4,6]}')
{ "a": [ [ " ", 4 ], [ "-", 5 ], [ "+", 6 ] ] }
Object property keys:
- Object keys that are deleted or added between two objects are marked as such:
json-diff.js --full --raw-json <(echo '{"a":[4,5]}') <(echo '{"b":[4,5]}')
{ "a__deleted": [ 4, 5 ], "b__added": [ 4, 5 ] }
json-diff.js --full --raw-json <(echo '{"a":[4,5]}') <(echo '{"b":[4,6]}')
{ "a__deleted": [ 4, 5 ], "b__added": [ 4, 6 ] }
Non-full mode
- In regular, delta-only (non-"full") mode, equal properties and values are omitted:
json-diff.js --raw-json <(echo '{"a":4, "b":6}') <(echo '{"a":5,"b":6}')
{ "a": { "__old": 4, "__new": 5 } }
- Equal array elements are represented by a one-tuple containing only a space " ":
json-diff.js --raw-json <(echo '[1,7,3]') <(echo '[1,2,3]')
[ [ " " ], [ "-", 7 ], [ "+", 2 ], [ " " ] ]
Tests
Run:
npm test
Output:
Open to View Test Output ð½
json-diff@0.5.3 test
coffee -c test; mocha test/*.js
colorizeToArray
â should return '
colorize â should return a string with ANSI escapes â should return a string without ANSI escapes on { color: false }
diff
with simple scalar values
â should return undefined for two identical numbers
â should return undefined for two identical strings
â should return { __old:
diff({sort: true}) with arrays â should return undefined for two arrays with the same contents in different order
diff({keepUnchangedValues: true}) with nested object â should return partial object with modified and unmodified elements in the edited scope
diff({full: true})
with simple scalar values
â should return the number for two identical numbers
â should return the string for two identical strings
â should return { __old:
diff({ outputKeys: foo,bar } â should return keys foo and bar although they have no changes â should return keys foo (with addition) and bar (with no changes) â should return keys foo and bar (with addition) â should return nothing as the entire object is equal, no matter that show keys has some of them â should return the keys of an entire object although it has no changes
diff({keysOnly: true})
with simple scalar values
â should return undefined for two identical numbers
â should return undefined for two identical strings
â should return undefined object for two different numbers
with objects
â should return undefined for two empty objects
â should return undefined for two objects with identical contents
â should return undefined for two object hierarchies with identical contents
â should return {
diffString â should produce the expected result for the example JSON files â should produce the expected result for the example JSON files with precision set to 1 â should produce the expected colored result for the example JSON files â return an empty string when no diff found
diff({ outputNewOnly: true } â should return only new diffs (added) â should return only new diffs (changed) â should return only new diffs (deleted) â should return only old diffs - exchanged first and second json (added) â should return only old diffs - exchanged first and second json (changed) â should return only old diffs - exchanged first and second json (deleted)
107 passing (74ms)
Change Log
- 1.0.6 Comment out another debugging output.
- 1.0.5 Comment out debugging output(!)
- 1.0.4 Fix typo that broke -o/--output-keys
- 1.0.3 Change from cli-color to colors to reduce package size.
- 1.0.2 Add colorize and colorizeToCallback to module exports (Fix bug #103)
- 1.0.1 Bug fixes: Properly compare date objects; properly exclude keys with -x; improve README readability.
- 1.0.0 Properly distinguish list elements with identical strings of different types e.g.
["true"]
vs[true]
,["0"]
vs[0]
(enabled by switching to a new difflib) - 0.10.0 Add --exclude-keys
- 0.9.1 Fix bug #88
- 0.9.0 Add --output-new-only option
- 0.8.0 Add --keep-unchanged-values option
- 0.7.4 Fix bug #76
- 0.7.3 Revert use of ?? operator in 0.7.2 (which caused a breaking change)
- 0.7.2 Add --maxElisions and --precision options.
- 0.7.1 Add --output-keys option.
- 0.7.0 Add --sort option.
- 0.6.3 Fix ticket #68.
- 0.6.2 Provide examples of setting mode from code.
- 0.6.1 Return exit code 0. Update cli-color to the latest version.
- 0.6.0 Convert project code to ES6.
- 0.5.5 Fix bug in scalarize fuzzy compare logic.
- 0.4.0 Add --keys-only feature.
License
© Andrey Tarantsov. Distributed under the MIT license.
Top Related Projects
Ace (Ajax.org Cloud9 Editor)
Diff & patch JavaScript objects
Diff Match Patch is a high-performance library in multiple languages that manipulates plain text.
A javascript text differencing implementation.
Javascript utility for calculating deep difference, capturing changes, and applying changes across objects; for nodejs and the browser.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot