Implements a JSX interface for Babel API.
You're likely not going to use this directly.
Exports the following items:
jsx (tag, {children?, ...attrs}, key?)
– a replacement for single-child (or childless) JSX elementjsxs (tag, {children=[], ...attrs}, key?)
– a replacement for multi-child JSX elementFragment
– thetag
value for<>
tags (equals to'<>'
, as per Hiccup definition)
In order to use mreframe
with JSX, you need to do the following:
- install NPM packages
@babel/cli
,@babel/core
,@babel/plugin-transform-react-jsx
; optionally@babel/plugin-transform-modules-commonjs
(to use produced files directly in browser) - configure Babel (i.e. in
.babelrc
):{ "plugins": [ ["@babel/plugin-transform-react-jsx", { "runtime": "automatic", "importSource": "mreframe" }], // uncomment this to have require() instead of import; this makes JSX output messier though //["@babel/plugin-transform-modules-commonjs"] ] }
- add a
scripts
command (inpackage.json
) to run Babel; e.g.such a command can be run as{ ... "scripts": { "build": "babel src/ -d dist/" } ... }
npm run build
(oryarn build
when usingyarn
)
JSX is not particularly compatible with Reagent-style components; you're likely to encounter following issues:
-
component arguments have to be passed as
children
array; this may take one of the following forms:<Component>{[foo, bar, baz]}</Component>
<Component>{foo}{bar}{baz}</Component}
<Component children={[foo, bar, baz]}/>
{[Component, foo, bar, baz]}
-
single arguments can be passed without wrapping into an array… unless it's an array value: in this case not wrapping it would result in it being treated as an argument list
-
attributes can be used, but they're not included in the component arguments; they're passed as
meta
/attrs
(i.e.r.props( r.currentComponent() )
) -
native (Mithril) components must be adapted before you can use them
-
attributes named
children
orargv
are unsupported