-
Notifications
You must be signed in to change notification settings - Fork 790
Optional Self hosting
This page documents advice for people wanting to build ClojureScript projects that want or need to leverage cljs.js/eval-str
and other self-hosted functionality.
WARNING: If you are building a web application where the final size of the deployed artifact matters significantly you should not be leveraging any of the functionality outlined on this page.
You can leverage :optimization :simple
with builds that include the cljs.js
namespace. Other recommended settings:
:pretty-print false
:optimize-constants true
:static-fns true
:optimize-constants
is significant for code size, all keys and symbols in your source will be compiled into a single lookup table.
By default for ease of use cljs.js/empty-state
will dump the analysis cache for cljs.core
. This doubles the size of the final file. You can disable this with setting :dump-core false
in your compiler build options.
This means you will need to load the analysis for for yourself for example that might look something like this:
(def st (cljs.js/empty-state))
;; path to Transit encoded analysis cache
(def cache-url "/assets/js/cljs_next/cljs/core.cljs.cache.aot.json")
(defn main []
(http/get cache-url
(fn [json]
(let [rdr (transit/reader :json)
cache (transit/read rdr json)]
(cljs.js/load-analysis-cache! st 'cljs.core cache)
;; ...
))))
- Rationale
- Quick Start
- Differences from Clojure
- [Usage of Google Closure](Google Closure)