mirror of
https://github.com/status-im/re-frame.git
synced 2025-02-23 07:18:22 +00:00
Tweaks to the readme
This commit is contained in:
parent
25ed816603
commit
70987e5318
89
README.md
89
README.md
@ -1,4 +1,4 @@
|
||||
# re-frame: Derived Values, Flowing [data:image/s3,"s3://crabby-images/01322/013222775bb72789f1a85c0f991cc527021e26f0" alt="Build Status"](https://travis-ci.org/Day8/re-frame)
|
||||
# re-frame: Derived Values, Flowing
|
||||
|
||||
|
||||
> This, milord, is my family's axe. We have owned it for almost nine hundred years, see. Of course,
|
||||
@ -23,10 +23,12 @@ Either:
|
||||
|
||||
## re-frame
|
||||
|
||||
re-frame is a pattern for writing [SPAs] in ClojureScript, using [Reagent].
|
||||
re-frame is a pattern for writing [SPAs] in ClojureScript, using [Reagent].
|
||||
|
||||
This repo contains both a **description of this pattern** and a **reference implementation**.
|
||||
|
||||
To quote McCoy: "It's MVC, Jim, but not as we know it".
|
||||
|
||||
To build a re-frame app, you:
|
||||
- design your app's data structure (data layer)
|
||||
- write and register subscription functions (query layer)
|
||||
@ -54,13 +56,18 @@ Features:
|
||||
It also has a charming xkcd reference (soon)
|
||||
and a hilarious, insiders-joke T-shirt, ideal for conferences (in design).
|
||||
What could possibly go wrong?
|
||||
|
||||
## Using It
|
||||
|
||||
__Warning__: this is a long document. That was the summary. The rest is a tutorial.
|
||||
[data:image/s3,"s3://crabby-images/01322/013222775bb72789f1a85c0f991cc527021e26f0" alt="Build Status"](https://travis-ci.org/Day8/re-frame)
|
||||
|
||||
[data:image/s3,"s3://crabby-images/1f160/1f1603b78d91e731de7309f95d6c13dd7bb07551" alt="Clojars Project"](http://clojars.org/re-frame)
|
||||
|
||||
__Warning__: okay, that was the summary. What follows is a lengthy tutorial with a [Where Do I Go Next](#Where-Do-I-Go-Next) section at the end.
|
||||
|
||||
|
||||
## Table of Contents
|
||||
|
||||
*generated by [DocToc](https://github.com/thlorenz/doctoc)*
|
||||
## Tutorial Table of Contents
|
||||
|
||||
|
||||
- [What Problem Does It Solve?](#what-problem-does-it-solve)
|
||||
- [Correct Acronym?](#correct-acronym)
|
||||
@ -69,33 +76,34 @@ __Warning__: this is a long document. That was the summary. The rest is a tutor
|
||||
- [Guiding Philosophy](#guiding-philosophy)
|
||||
- [FRP Clarifications](#frp-clarifications)
|
||||
- [Explaining re-frame](#explaining-re-frame)
|
||||
- [On Data](#on-data)
|
||||
- [The Big Ratom](#the-big-ratom)
|
||||
- [The Benefits Of Data-In-The-One-Place](#the-benefits-of-data-in-the-one-place)
|
||||
- [On Data](#on-data)
|
||||
- [The Big Ratom](#the-big-ratom)
|
||||
- [The Benefits Of Data-In-The-One-Place](#the-benefits-of-data-in-the-one-place)
|
||||
- [Flow](#flow)
|
||||
- [How Flow Happens In Reagent](#how-flow-happens-in-reagent)
|
||||
- [How Flow Happens In Reagent](#how-flow-happens-in-reagent)
|
||||
- [Components](#components)
|
||||
- [Truth Interlude](#truth-interlude)
|
||||
- [Components Like Templates?](#components-like-templates)
|
||||
- [React etc.](#react-etc)
|
||||
- [Truth Interlude](#truth-interlude)
|
||||
- [Components Like Templates?](#components-like-templates)
|
||||
- [React etc.](#react-etc)
|
||||
- [Subscribe](#subscribe)
|
||||
- [Just A Read-Only Cursor?](#just-a-read-only-cursor)
|
||||
- [Just A Read-Only Cursor?](#just-a-read-only-cursor)
|
||||
- [The Signal Graph](#the-signal-graph)
|
||||
- [A More Efficient Signal Graph](#a-more-efficient-signal-graph)
|
||||
- [The 2nd Flow](#the-2nd-flow)
|
||||
- [Event Flow](#event-flow)
|
||||
- [What are events?](#what-are-events)
|
||||
- [Dispatching Events](#dispatching-events)
|
||||
- [Event Handlers](#event-handlers)
|
||||
- [Routing](#routing)
|
||||
- [Control Via FSM](#control-via-fsm)
|
||||
- [As A Reduce](#as-a-reduce)
|
||||
- [Derived Data, Everywhere, flowing](#derived-data-everywhere-flowing)
|
||||
- [Logging And Debugging](#logging-and-debugging)
|
||||
- [Talking To A Server](#talking-to-a-server)
|
||||
- [What are events?](#what-are-events)
|
||||
- [Dispatching Events](#dispatching-events)
|
||||
- [Event Handlers](#event-handlers)
|
||||
- [Routing](#routing)
|
||||
- [Control Via FSM](#control-via-fsm)
|
||||
- [As A Reduce](#as-a-reduce)
|
||||
- [Derived Data, Everywhere, flowing](#derived-data-everywhere-flowing)
|
||||
- [Logging And Debugging](#logging-and-debugging)
|
||||
- [Talking To A Server](#talking-to-a-server)
|
||||
- [The CPU Hog Problem](#the-cpu-hog-problem)
|
||||
- [In Summary](#in-summary)
|
||||
- [Licence](#licence)
|
||||
- [In Summary](#in-summary)
|
||||
- [Where Do I Go Next](#Where-Do-I-Go-Next)
|
||||
- [Licence](#licence)
|
||||
|
||||
## What Problem Does It Solve?
|
||||
|
||||
@ -129,7 +137,7 @@ but not as we know it".
|
||||
In re-frame, none of the M, V, or C bits are objects, they
|
||||
are pure functions (or pure data),
|
||||
and they are all wired together via reactive data flows. It is sufficiently different in nature
|
||||
from (traditional, Smalltalk) MVC that calling it MVC would likely just be confusing. I'd
|
||||
from (traditional, Smalltalk) MVC that calling it MVC would likely just be confusing. So, I'd
|
||||
love an alternative.
|
||||
|
||||
Perhaps it is a RACES framework - Reactive-Atom Component Event
|
||||
@ -146,13 +154,13 @@ insider's joke, conference T-Shirt.
|
||||
Not much about re-frame is original or clever. You'll find
|
||||
no ingenious use of functional zippers, transducers or core.async.
|
||||
|
||||
Re-frame does use Reagent's features in a slightly novel way.
|
||||
And I did actively reject the current ClojureScript fashion of using Cursors.
|
||||
But, for the most part, re-frame is just a mashup of
|
||||
Re-frame does use Reagent's features in a novel way.
|
||||
And I did actively reject the current ClojureScript fashion of using
|
||||
Cursors. And, yes, the event middleware concept has turned out nicely.
|
||||
But, for the most part, re-frame is simply a mashup of
|
||||
emerging ideas.
|
||||
|
||||
(For the record,
|
||||
one day I'd love to develop something original and clever).
|
||||
(For the record, one day I'd love to develop something original and clever).
|
||||
|
||||
|
||||
## Client Side Bias
|
||||
@ -438,7 +446,7 @@ no parameters and it returns a ClojureScript vector (formatted as Hiccup).
|
||||
Here is a slightly more interesting (parameterised) component (function):
|
||||
|
||||
```Clojure
|
||||
(defn greet ;; greet has a parameter now
|
||||
(defn greet ;; greet has a parameter now
|
||||
[name] ;; 'name' is a ratom holding a string
|
||||
[:div "Hello " @name]) ;; dereference 'name' to extract the contained value
|
||||
|
||||
@ -463,7 +471,7 @@ because in a minute, when we get to `subscriptions`, we'll be directly using `re
|
||||
might as well bite the bullet here and now ... and, anyway, it is pretty easy...
|
||||
|
||||
```Clojure
|
||||
(defn greet ;; a component - data in, Hiccup out.
|
||||
(defn greet ;; a component - data in, Hiccup out.
|
||||
[name] ;; name is a ratom
|
||||
[:div "Hello " @name]) ;; dereference name here, to extract the value within
|
||||
|
||||
@ -1092,7 +1100,7 @@ How did that exception happen, you wonder, shaking your head? What did the user
|
||||
to the exception? What state was the app in that this event was so disastrous?
|
||||
|
||||
To debug it, you need to know this information:
|
||||
1. the state the app immediately before the exception
|
||||
1. the state of the app immediately before the exception
|
||||
2. What final event then caused your app to fall in a screaming mess.
|
||||
|
||||
Well, with re-frame you need to record (have available):
|
||||
@ -1169,6 +1177,19 @@ To build an app using re-frame, you'll have to:
|
||||
- write and register event handler functions (control layer and/or state transition layer).
|
||||
|
||||
|
||||
### Where Do I Go Next?
|
||||
|
||||
Your next steps with re-frame should be:
|
||||
- look at the examples: https://github.com/Day8/re-frame/tree/master/examples
|
||||
- use the lein template: https://github.com/Day8/re-frame-template
|
||||
- read more in the Wiki: https://github.com/Day8/re-frame/wiki
|
||||
|
||||
You might also be interested in James MacAulay's excellent work (not re-frame!):
|
||||
https://github.com/jamesmacaulay/zelkova
|
||||
|
||||
If you want reusable layout and widget components, consider this sister project:
|
||||
https://github.com/Day8/re-com
|
||||
|
||||
### Licence
|
||||
|
||||
Copyright © 2015 Michael Thompson
|
||||
|
Loading…
x
Reference in New Issue
Block a user