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
|
## 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
|
#### Headline
|
||||||
|
|
||||||
|
@ -226,14 +226,15 @@ after those dominoes.
|
|||||||
|
|
||||||
## As Code Fragments
|
## 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.
|
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.
|
**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
|
> Don't expect
|
||||||
to completely grok the terse code presented below. We're still at 30,000 feet. Details later.
|
to completely grok the terse code presented below. We're still at 30,000 feet. Details later.
|
||||||
|
@ -109,12 +109,12 @@ presumably the id of the item to delete.
|
|||||||
Here are some other example events:
|
Here are some other example events:
|
||||||
|
|
||||||
```clj
|
```clj
|
||||||
[:yes-button-clicked]
|
[:admit-to-being-satoshi false]
|
||||||
[:set-spam-wanted false :continue-harassment-nevertheless-flag]
|
[: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
|
The `kind` of event is always a keyword, and for non-trivial
|
||||||
applications it tends to be namespaced.
|
applications it tends to be namespaced.
|
||||||
|
|
||||||
**Rule**: events are pure data. No sneaky tricks like putting
|
**Rule**: events are pure data. No sneaky tricks like putting
|
||||||
@ -127,7 +127,7 @@ To send an event, call `dispatch` with the event vector as argument:
|
|||||||
(dispatch [:event-id value1 value2])
|
(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
|
```clj
|
||||||
(defn dispatch-timer-event
|
(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.
|
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
|
### reg-event-db
|
||||||
|
|
||||||
We register event handlers using re-frame's `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-event-handler-fn)
|
||||||
```
|
```
|
||||||
The handler function you provide should expect two parameters:
|
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
|
- `v` the event vector
|
||||||
|
|
||||||
So, your function will have a signature like this: `(fn [db v] ...)`.
|
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
|
the application, which means it normally returns a
|
||||||
modified version of `db`.
|
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
|
### :initialize
|
||||||
|
|
||||||
On startup, application state must be initialised. We
|
On startup, application state must be initialised. We
|
||||||
|
Loading…
x
Reference in New Issue
Block a user