jsx-jsonml-devtools-renderer
v1.4.3
Published
A JSX render for Chrome Devtools.
Downloads
23
Readme
jsx-jsonml-devtools-renderer
This is a Custom Object Formatter for rendering JSX objects in Chrome Devtools. Yes, you can see them in the console now!
How to use
import React from "jsx-jsonml-devtools-renderer";
class MyObject {
type = 1;
innerData = "innerData";
}
class MyObjectCustomFormatter implements React.CustomObjectFormatter {
hasBody(obj: unknown) {
if (obj instanceof MyObject) return true;
return false;
}
body(obj: MyObject) {
return (
<div>
<table>
<tr style="background: rgba(255, 255, 255, 0.6)">
<td style="min-width: 4em">Type</td>
<td>Value</td>
</tr>
<tr>
<td>{obj.type}</td>
<td>{obj.innerData}</td>
</tr>
</table>
</div>
);
}
header(obj: unknown) {
if (!(obj instanceof MyObject)) return null;
return <div>MyObject (type: {obj.type})</div>;
}
}
React.installCustomObjectFormatter(new MyObjectCustomFormatter());
Standard Custom Object Formatters features
| | div | span | ol | li | table | tr | td | object | | ------ | --- | ---- | --- | --- | ----- | --- | --- | ------ | | style | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ❌ | | object | ❌ | ❌ | ❌ | ❌ | ❌ | ❌ | ❌ | ✔ |
NON-Standard Custom Object Formatters features
- an
onClick
attribute is available for any tags exceptobject
. Due to technical limitation, theonClick
event will be only fired once. - an
img
tag. With attributessrc
(required),width
(optional) andheight
(optional) - a
code
tag. - a
br
tag. - a
variant
attribute is available for any tags exceptobject
. It can used to specify some default styles.
APIs
- Fragment (Used to support
<></>
syntax) - createElement (used to support JSX)
- createElementTyped (same as createElement, but have a more stricter type)
installCustomObjectFormatter(formatter)
(install the formatter to Chrome devtools)isJSXElement(x)
is it a JSX Elementconst [state, setState, forceRender] = useState(inspectedObject, initialStateCreator)
(used to preserve states between renders)
JSX Features
Basic usage
return (
<div style="opacity: 0.7;">
Content
<span>(Note)</span>
</div>
)
Display an object
return (
<span>
The explicit way: <object object={window} />
The implicit way: {window}. If window is `null`, renderer will ignore this element.
</span>
)
Array#map
return (
<span>
{data.map(x => (
<object object={x} />
))}
</span>
)