mirror of
https://github.com/status-im/re-frame.git
synced 2025-02-23 15:28:09 +00:00
Docs WIP
This commit is contained in:
parent
f4df4777c3
commit
742349348d
@ -1,6 +1,7 @@
|
||||
## 0.9.0 (2016.12.DD) Unreleased
|
||||
|
||||
Dr Ford has created a new re-frame narrative, and Bernard some infographics. Anyone seen Delores?
|
||||
Dr Ford has created a new [6-part narrative](README.md),
|
||||
and Bernard [some infographics](/docs/EventHandlingInfographic.md). Anyone seen Delores?
|
||||
|
||||
#### Headline
|
||||
|
||||
|
@ -226,14 +226,15 @@ after those dominoes.
|
||||
|
||||
## As Code Fragments
|
||||
|
||||
Let's take this domino narrative one step further and introduce some code fragments.
|
||||
Let's take this domino narrative further and introduce code fragments.
|
||||
We're going to be working on a SPA with a list of items.
|
||||
|
||||
data:image/s3,"s3://crabby-images/54ead/54ead7b8cd9582fd2d9fbd6c0d854659723bc0c7" alt="Example SPA todo list"
|
||||
<img src="/images/Readme/todolist.png?raw=true">
|
||||
|
||||
**Imagine:** You have just clicked the "delete" button next to the 3rd item in the list.
|
||||
|
||||
In response, what happens within this imaginary re-frame app? Here's a sketch of the six domino cascade:
|
||||
In response, what happens within this imaginary re-frame app? Here's a sketch
|
||||
of the six domino cascade:
|
||||
|
||||
> Don't expect
|
||||
to completely grok the terse code presented below. We're still at 30,000 feet. Details later.
|
||||
|
@ -109,9 +109,9 @@ presumably the id of the item to delete.
|
||||
Here are some other example events:
|
||||
|
||||
```clj
|
||||
[:yes-button-clicked]
|
||||
[:admit-to-being-satoshi false]
|
||||
[:set-spam-wanted false :continue-harassment-nevertheless-flag]
|
||||
[:some-ns/on-success response]
|
||||
[:some-ns/on-GET-success response]
|
||||
```
|
||||
|
||||
The `kind` of event is always a keyword, and for non-trivial
|
||||
@ -127,7 +127,7 @@ To send an event, call `dispatch` with the event vector as argument:
|
||||
(dispatch [:event-id value1 value2])
|
||||
```
|
||||
|
||||
In this "simple" app, a `:timer` event is sent every second:
|
||||
In this "simple" app, a `:timer` event is dispatched every second:
|
||||
```clj
|
||||
(defn dispatch-timer-event
|
||||
[]
|
||||
@ -171,6 +171,22 @@ In this application, 3 kinds of event are dispatched:
|
||||
|
||||
3 events means we'll be registering 3 event handlers.
|
||||
|
||||
### Two ways To register
|
||||
|
||||
Event handlers can be registered via either `reg-event-db`
|
||||
or `reg-event-fx` (`-db` vs `-fx`).
|
||||
|
||||
Handler functions take coeffects (input args) and return `effects`,
|
||||
however `reg-event-db` allows you to write simpler handlers.
|
||||
The
|
||||
handler functions it registers
|
||||
(1) take just one coeffect - the current app state and (2) return only one `effect` -
|
||||
the updated app state.
|
||||
|
||||
Whereas `reg-event-fx` registered handlers are more flexible.
|
||||
|
||||
Because of its simplicity, we'll be using the former here.
|
||||
|
||||
### reg-event-db
|
||||
|
||||
We register event handlers using re-frame's `reg-event-db`.
|
||||
@ -182,7 +198,7 @@ We register event handlers using re-frame's `reg-event-db`.
|
||||
the-event-handler-fn)
|
||||
```
|
||||
The handler function you provide should expect two parameters:
|
||||
- `db` the current application state
|
||||
- `db` the current application state (contents of `app-db`)
|
||||
- `v` the event vector
|
||||
|
||||
So, your function will have a signature like this: `(fn [db v] ...)`.
|
||||
@ -191,16 +207,6 @@ Each event handler must compute and return the new state of
|
||||
the application, which means it normally returns a
|
||||
modified version of `db`.
|
||||
|
||||
> **Note**: generally event handlers return `effects`. `reg-event-db` is used
|
||||
to register a certain kind of simple event handler, one where
|
||||
(1) the only inputs (`coeffects`)
|
||||
required for the computation are `db` and `v`, and (2) the only `effect`
|
||||
returned is an update to app state.
|
||||
|
||||
> There is a more sophisticated registration function called
|
||||
`reg-event-fx` which allows more varied `coeffects` and `effects`
|
||||
to be computed. More on this soon.
|
||||
|
||||
### :initialize
|
||||
|
||||
On startup, application state must be initialised. We
|
||||
|
Loading…
x
Reference in New Issue
Block a user