
Company News
Socket Named Top Sales Organization by RepVue
Socket won two 2026 Reppy Awards from RepVue, ranking in the top 5% of all sales orgs. AE Alexandra Lister shares what it's like to grow a sales career here.
react-json-tree
Advanced tools
React JSON Viewer Component, Extracted from redux-devtools. Supports iterable objects, such as Immutable.js.
import { JSONTree } from 'react-json-tree';
// If you're using Immutable.js: `npm i --save immutable`
import { Map } from 'immutable';
// Inside a React component:
const json = {
array: [1, 2, 3],
bool: true,
object: {
foo: 'bar',
},
immutable: Map({ key: 'value' }),
};
<JSONTree data={json} />;

Check out examples directory for more details.
This component now uses react-base16-styling module, which allows to customize component via theme property, which can be the following:
{ style, className } and should return an object with the same structure. Other arguments depend on particular context (and should be described here). See createStylingFromTheme.js for the list of styling object keys. Also, this object can extend base16 theme via extend property.Every theme has a light version, which is enabled with invertTheme prop.
const theme = {
scheme: 'monokai',
author: 'wimer hazenberg (http://www.monokai.nl)',
base00: '#272822',
base01: '#383830',
base02: '#49483e',
base03: '#75715e',
base04: '#a59f85',
base05: '#f8f8f2',
base06: '#f5f4f1',
base07: '#f9f8f5',
base08: '#f92672',
base09: '#fd971f',
base0A: '#f4bf75',
base0B: '#a6e22e',
base0C: '#a1efe4',
base0D: '#66d9ef',
base0E: '#ae81ff',
base0F: '#cc6633',
};
<div>
<JSONTree data={data} theme={theme} invertTheme={false} />
</div>;

<div>
<JSONTree
data={data}
theme={{
extend: theme,
// underline keys for literal values
valueLabel: {
textDecoration: 'underline',
},
// switch key for objects to uppercase when object is expanded.
// `nestedNodeLabel` receives additional argument `expandable`
nestedNodeLabel: ({ style }, keyPath, nodeType, expanded) => ({
style: {
...style,
textTransform: expanded ? 'uppercase' : style.textTransform,
},
}),
}}
/>
</div>
You can pass getItemString to customize the way arrays, objects, and iterable nodes are displayed (optional).
By default, it'll be:
<JSONTree getItemString={(type, data, itemType, itemString, keyPath)
=> <span>{itemType} {itemString}</span>}
But if you pass the following:
const getItemString = (type, data, itemType, itemString, keyPath)
=> (<span> // {type}</span>);
Then the preview of child elements now look like this:

You can pass the following properties to customize rendered labels and values:
<JSONTree
labelRenderer={([key]) => <strong>{key}</strong>}
valueRenderer={(raw) => <em>{raw}</em>}
/>
In this example the label and value will be rendered with <strong> and <em> wrappers respectively.
For labelRenderer, you can provide a full path - see this PR.
Their full signatures are:
labelRenderer: function(keyPath, nodeType, expanded, expandable)valueRenderer: function(valueAsString, value, ...keyPath)shouldExpandNodeInitially: function(keyPath, data, level) - determines if node should be expanded when it first renders (root is expanded by default)hideRoot: boolean - if true, the root node is hidden.sortObjectKeys: boolean | function(a, b) - sorts object keys with compare function (optional). Isn't applied to iterable maps like Immutable.Map.postprocessValue: function(value) - maps value to a new valueisCustomNode: function(value) - overrides the default object type detection and renders the value as a single valuecollectionLimit: number - sets the number of nodes that will be rendered in a collection before rendering them in collapsed rangeskeyPath: (string | number)[] - overrides the initial key path for the root node (defaults to [root])redux-devtools monorepo from alexkuz/react-json-tree.MIT
react-json-view is a React component for displaying and editing JSON data. It provides a more interactive experience compared to react-json-tree, allowing users to edit JSON values directly within the tree structure. It also supports features like collapsing/expanding nodes, searching, and custom themes.
jsoneditor-react is a wrapper around the JSONEditor library for use in React applications. It offers a rich set of features for viewing, editing, and manipulating JSON data, including a tree view, code view, and text view. It is more feature-rich compared to react-json-tree, providing advanced functionalities like schema validation and history management.
react-json-inspector is a React component for inspecting JSON data. It provides a simple and efficient way to navigate through large JSON objects. Unlike react-json-tree, it focuses more on search and filtering capabilities, making it easier to find specific data within a large JSON structure.
FAQs
React JSON Viewer Component, Extracted from redux-devtools
The npm package react-json-tree receives a total of 770,084 weekly downloads. As such, react-json-tree popularity was classified as popular.
We found that react-json-tree demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Company News
Socket won two 2026 Reppy Awards from RepVue, ranking in the top 5% of all sales orgs. AE Alexandra Lister shares what it's like to grow a sales career here.

Security News
NIST will stop enriching most CVEs under a new risk-based model, narrowing the NVD's scope as vulnerability submissions continue to surge.

Company News
/Security News
Socket is an initial recipient of OpenAI's Cybersecurity Grant Program, which commits $10M in API credits to defenders securing open source software.