A RequireJS plugin which uses Babel to allow you to write React apps with no build step, no Webpack, not even Node.js installed. Just you and a text editor, like in the old jQuery days: write and run in the browser right away.
It has support to JS classes, decorators, and even Redux and MobX. It's based on this and this. Babel presets and plugins are configurable.
You shouldn't. This is an experimental project, more a proof-of-concept than a production tool.
However, it has been useful to me in situations where I wanted to write a small app really quick, and slow performance was tolerable; and also to some quick prototyping. So it's not completely useless, actually.
See the examples.
You can run the examples by installing http-server, then running it from the root directory. Using the default 8080 port, the first example will be available at:
You can host react-require.min.js
locally or use RawGit CDN:
requirejs.config({
paths: {
'jsx': 'https://cdn.rawgit.com/rodrigocfd/react-require/master/react-require.min'
}
});
In particular, choice of Babel presets and plugins can be overriden. These are the default values:
window.babelConfig = {
presets: ['es2015', 'react'],
plugins: ['transform-class-properties', 'transform-decorators-legacy']
};
Also, the libraries you are importing are defined in requirejs.config()
.
All the configurations described above can be seen in an embedded <script>
in the index.html
files of the examples. You can extract this <script>
into a separated JS file, if you want to.
-
Since we're loading all the JS files on-the-fly in the browser, the app will have a little lag before it's shown on the screen. That's the time needed for RequireJS to load all files, and Babel to process all of them.
-
The amount of bytes to be downloaded by the browser is much bigger than a properly compiled, minified, packaged app.
-
Since we're using production versions of React libraries, some validations, like
propTypes
, won't show up in the console. You can change these libraries to development versions though, at the cost of making the app even slower.
Because a friend of mine said it was not possible.
And it was fun to do.