This is a proof-of-concept to allow React JSX standalone components in existing legacy applications that might not allow for upgrading to a full-fledged React SPA.
Using React's lazy
function, app.js
goes through all of the jsx
files and
dynamically imports them. This lazy component is then rendered inside a
Suspense
component, which allows for rendering fallback content while waiting
for the lazily-loaded component to load.
Each of the components in the template are standalone React apps. For this reason, an event bus pattern was also added to demonstrate a quick and dirty way to communicate between different apps on the same page.
Run the below commands to clone this repo onto your machine, install any npm
dependencies and serve the site.
git clone git@github.com:dstrunk/inline-jsx.git && cd $1
yarn install && yarn serve
After running the above commands, open up your browser to localhost:3000
to
see inline JSX in action!