Overview¶
The re-frame API consists of:
- the namespace re-frame.core
- a set of built-in effects
In the navigation to the left, you'll see a link to both.
Dependency Information¶
Please review both the releases page and the Clojars page to discover the version you should be using.
Using re-frame¶
To use the re-frame API within your namespace, you'll 
need to require it, perhaps like this:
(ns my-app.some-namespace
  (:require [re-frame.core :as rf]))
;; your code hereYou'll then be able to use the functions in the API, perhaps like this: rf/dispatch.
The Most Commonly Used Part Of The API¶
When you are writing View Functions: 
- dispatch(or occasionally,- dispatch-sync)
- subscribe
When you are registering:
- event handlers - reg-event-dbandreg-event-fx
- subscription handlers - reg-sub(and rarelyreg-sub-raw)
- rarely, effect handlers - reg-fx
- rarely, coeffect handlers - reg-cofxwithinject-cofx
When you register event handlers, you might use builtin interceptors: 
- path
- on-change
- enrich
- after
- trim-v
- debug
Global interceptors can be very useful:
- register them via reg-global-interceptors
- rarely, remove them via clear-global-interceptor
When errors arise:
- Catch them from events and interceptors via reg-event-error-handler
More Rarely Used Part¶
Testing or dev-time related utilities:
- clear-subscription-cache!
- make-restore-fn
- purge-event-queue
Logging/debugging:
- console
- set-loggers
If you write an Interceptor, use these utilities. To see how they are used, look at the re-frame code for builtin Interceptors:
- ->interceptor
- get-coeffect
- assoc-coeffect
- get-effect
- assoc-effect
- enqueue