Bindings to React for js_of_ocaml, including JSX ppx.
Adapted from ReasonReact.
jsoo-react
allows to use React from OCaml, but it is still at the experimental phase: there is no published version in opam yet, and the library is expected to break backwards compatibility often.
Bug reports and contributions are welcome!
For new projects, the best way to start is by using Spin with the spin-jsoo-react
template.
-
First, install Spin following the instructions.
-
Then run:
spin new https://github.com/tmattio/spin-jsoo-react.git
After that, check the newly created project readme to get started.
-
Install the
jsoo-react
package:opam pin add -y jsoo-react https://github.com/ml-in-barcelona/jsoo-react.git
-
Add
jsoo-react
library and ppx to dune file of your executable JavaScript app:(executables (names index) (modes js) (libraries jsoo-react.lib) (preprocess (pps jsoo-react.ppx)))
-
Provision React.js library
jsoo-react
does not make any assumptions about how you will load React.js in your application. There are 2 ways of doing so:If you want to use Webpack, Rollup, Parcel or any other JavaScript bundler, include a file
react-requires.js
in your application source folder with the following content:joo_global_object.React = require('react'); joo_global_object.ReactDOM = require('react-dom');
Then add it to your application
dune
file so it can be linked:(executables ... (js_of_ocaml (javascript_files react-requires.js)))
To see an example of this approach, check the example folder.
Note that at this moment,
jsoo-react
is compatible with React 16, so be sure to have the appropriate constraints in yourpackage.json
.If you are not using any JavaScript bundlers, and just loading the
bc.js
artifact generated by Dune, you can just add the following HTML tags to yourindex.html
page:<script src="https://unpkg.com/react@16/umd/react.development.js" crossorigin></script> <script src="https://unpkg.com/react-dom@16/umd/react-dom.development.js" crossorigin></script>
Make sure they are loaded before your application
bc.js
artifact.
Take a look at our Contributing Guide.
Thanks to the authors and maintainers of ReasonReact, in particular @rickyvetter for his work on the v3 of the JSX ppx.
Thanks to the authors and maintainers of Js_of_ocaml, in particular @hhugo who has been answering many many questions in GitHub threads.
Thanks to the Lexifi team for creating and maintaining gen_js_api.
Thanks to @tmattio for creating Spin and the jsoo-react template 🙌
And thanks to the team behind React.js! What an amazing library :)