A simple way to bootstrap a ClojureScript (CLJS) web-app using:
-
Shadow-CLJS as the build tool / compiler
-
Reagent (CLJS wrapper around React) for building your user interface
Create your app in 5 easy steps:
Note that npx comes with npm 5.2+ and higher.
To create a project called my-project
, run this command in your Terminal:
npx create-reagent-app my-project
This will create a folder (in your current working directory) called my-project
, with the bootstrapped app as its contents.
Assuming you called your project my-project
:
cd my-project
Note: This step creates a node_modules
folder with all the dependencies in your project folder. You can use either yarn
or npm
as your package manager.
npm install
Note: Creates a package-lock.json
file in your project folder.
npm start
Then open http://localhost:3000/ in your browser to see your app.
Note: This approach to scaffolding an app was heavily inspired by create-react-app, a very popular way to get started with a ReactJS app in the JavaScript community.
Note also: Unlike the setup created by create-react-app, your project is not automatically initialized as a Git repo. However, a
.gitignore
file is included. Please rungit init
to create a Git repo in your project folder.
Running the following command (without options) creates a project using a basic template, without example usage or comments, which is most useful when you need a blank project scaffold:
npx create-reagent-app my-project
You can add the --example
option to the command to get a basic template with examples, which should be useful for developers who are not very familiar with setting up ClojureScript/Reagent projects with Shadow-CLJS. It has example components and plenty of comments:
npx create-reagent-app my-project --example
This will compile the app in development mode, and watch for any changes in your code. Open http://localhost:3000 to view the app in the browser.
npm start
This operation creates a .shadow-cljs
folder in your project folder.
This compiles the app in production mode, using :advanced
compilation settings. The finished build (under public/js
) will be in the public
folder, which can be deployed.
npm run build
This operation creates a .shadow-cljs
folder in your project folder.
Sometimes you may run into some release issues due to :advanced
compilation. The following command may help you track down the causes:
npm run debug-build
A detailed build report will be shown in your CLI, and a report.html
file will be created in your project folder.
npm run report
This will serve your finished build (from doing a production build via yarn build
or npm run build
, or from doing a development build via yarn devbuild
or npm run devbuild
) on http://localhost:5000 in your browser.
npm run serve
This compiles the app in developent mode once and then exits. The finished build will be in the public
folder. This command does not watch your code for changes (use yarn start
or npm start
to build the app in development mode and watch for changes).
npm run dev-build
This operation creates a .shadow-cljs
folder in your project folder.
From a different Terminal, connect to a browser REPL for your specific build (only available while yarn start
or npm start
is running, that is, Shadow-CLJS is “watching” your code for changes). Note also that your build must be running in the browser (localhost:3000
).
See this section of the Shadow-CLJS documentation for more details.
npm run repl
This starts a blank CLJS REPL and will open an associated browser window where the code will execute. It is not connected to any specific build target. Since it is not connected to any build it does not do any automatic rebuilding of code when your files change and does not provide hot-reload. If you close the browser window the REPL will stop working.
See this section of the Shadow-CLJS documentation for more details.
npm run browser-repl
A Clojure REPL is also provided in addition to the provided ClojureScript REPLs. This is can be used to control the shadow-cljs process and run all other build commands through it. You can start with a Clojure REPL and then upgrade it to a CLJS REPL at any point (and switch back).
See this section of the Shadow-CLJS documentation for more details.
npm run clojure-repl
(Run in a separate Terminal.) This runs the tests and watches them for changes, re-running when a change is detected.
npm test
Note: Creates an out
folder in your project folder, containing a node-tests.js
file.
(Run in a separate Terminal.) This runs the tests once and then exits. This command does not watch your tests for changes (use npm test
to run tests and watch for changes).
npm run test-once
Note: Creates an out
folder in your project folder.
Remove (“clean”) the public/js
folder and contents generated during compilation.
npm run clean
Remove all (“nuke”) of the following:
public/js
folder and contents.shadow-cljs
folder and contentsnode_modules
folder and contentspackage-lock.json
file (oryarn.lock
file, if you specified theyarn
option for your package manager)out
folder and contents (containing tests)report.html
file showing release build details
npm run nuke
Note that after this operation you will need to run npm install
again before starting the app, to re-install the dependencies.
Shadow-CLJS can be fairly slow to start. To improve this Shadow-CLJS can run in “server mode” which means that a dedicated process is started which all other commands can use to execute a lot faster since they won’t have to start a new JVM/Clojure instance.
You can run the process in the foreground in a dedicated Terminal. Use CTRL+C to terminate the server.
npm run shadow-cljs-server