react-json-view-lite is a tiny component for React allowing to render JSON as a tree. It focused more on the performance for large JSON inputs rather than customization and rich features. It is written in TypeScript and has no dependencies.
Install
npm install --save react-json-view-lite
Usage
import * as React from 'react';
import { JsonView, darkStyles, defaultStyles } from 'react-json-view-lite';
import 'react-json-view-lite/dist/index.css';
const json = {
a: 1,
b: 'example',
};
const App = () => {
return (
<React.Fragment>
<JsonView
data={json}
shouldInitiallyExpand={(level) => true}
style={defaultStyles}
/>
<JsonView data={json} shouldInitiallyExpand={(level) => true} style={darkStyles} />
</React.Fragment>
);
};
export default App;
Props
Name | Type | Default Value | Description |
---|
data | Object | Array<any> | | Data which should be rendered |
style | StyleProps | defaultStyles | CSS classes for rendering. Library provides two build-in implementations: darkStyles, defaultStyles |
shouldInitiallyExpand | (level: number, value: any, field?: string) => boolean | undefined | Optional. Function which will be initially called for each Object and Array of the data in order to calculate should if this node be expanded |
StyleProps
Name | Type | Description |
---|
container | string | CSS class name for rendering parent block |
basicChildStyle | string | CSS class name for property block containing property name and value |
expander | string | CSS class name for rendering button expanding/collapsing Object and Array nodes |
label | string | CSS class name for rendering property names |
nullValue | string | CSS class name for rendering null values |
undefinedValue | string | CSS class name for rendering undefined values |
numberValue | string | CSS class name for rendering numeric values |
stringValue | string | CSS class name for rendering string values |
booleanValue | string | CSS class name for rendering boolean values |
otherValue | string | CSS class name for rendering all other values except Object, Arrray, null, undefined, numeric, boolean and string |
punctuation | string | CSS class name for rendering , , [ , ] , { , } |
Comparison with other libraries
Here is the size benchmark (using bundlephobia.com) against similar React libraries (found by https://www.npmjs.com/search?q=react%20json&ranking=popularity):
Name | Bundle size | Bundle size (gzip) | Dependencies |
---|
react-json-view-lite | data:image/s3,"s3://crabby-images/c26e5/c26e58344f4e3d53978438ea52d199697f8ce7a1" alt="" | data:image/s3,"s3://crabby-images/66b38/66b386e6c6916e75f28db43132fc749890ffbb35" alt="" | data:image/s3,"s3://crabby-images/b3fee/b3fee29950d861af8ec1628f31cee590177782d9" alt="" |
react-json-pretty | data:image/s3,"s3://crabby-images/901b8/901b8cf15a168568347f048f31669ddf24957a91" alt="" | data:image/s3,"s3://crabby-images/9f429/9f429db51e406d8fca11444c0dc6c830b96588bf" alt="" | data:image/s3,"s3://crabby-images/895e1/895e1210a175fca0aaece30f17f95b6a7e909d9c" alt="" |
react-json-inspector | data:image/s3,"s3://crabby-images/67799/67799e9679e191fdf4bfc41add42f0bb00193005" alt="" | data:image/s3,"s3://crabby-images/b98ab/b98abb92b975f403ac8dce966e9e7f5538332af5" alt="" | data:image/s3,"s3://crabby-images/ecaa4/ecaa4593da11ad4a9cc19eb5ce1b230b0cec4592" alt="" |
react-json-tree | data:image/s3,"s3://crabby-images/47c70/47c70a9c3367227c64bbd6badcda95fe62536d44" alt="" | data:image/s3,"s3://crabby-images/99aab/99aabfb625993beaba2b5ca55f7ac6c5898c4822" alt="" | data:image/s3,"s3://crabby-images/14f4b/14f4b2e6d710064ade12797f03ac876063d20440" alt="" |
react-json-view | data:image/s3,"s3://crabby-images/77282/7728250a98280d5221edc869ab110debb102ace8" alt="" | data:image/s3,"s3://crabby-images/c0d80/c0d8096197f9bbb0db96d73d104be4ea4bf0e356" alt="" | data:image/s3,"s3://crabby-images/970a6/970a6220b895792c1f6f6648ee0778e4647075f7" alt="" |
react-json-tree-viewer | data:image/s3,"s3://crabby-images/5bd53/5bd53001d3a6277aebc98679e94b9e985a6844ad" alt="" | data:image/s3,"s3://crabby-images/a2ff2/a2ff29aebc80ed19ccb876fbbc35d93ebca16cd1" alt="" | data:image/s3,"s3://crabby-images/108ce/108ce892e430e5d86e4e3c218f4c924109d4e921" alt="" |
License
MIT © AnyRoad