mirror of
https://github.com/status-im/reagent.git
synced 2025-01-13 13:24:47 +00:00
One more example
This commit is contained in:
parent
9df8609f45
commit
0f45462034
@ -102,12 +102,19 @@
|
|||||||
(let [val (atom "foo")]
|
(let [val (atom "foo")]
|
||||||
(fn []
|
(fn []
|
||||||
[:div
|
[:div
|
||||||
[:p "The value of " [:code "val"] " is now: " @val]
|
[:p "The value is now: " @val]
|
||||||
[:p "Change it: "
|
[:p "Change it: "
|
||||||
[:input
|
[:input
|
||||||
{:type "text" :value @val
|
{:type "text" :value @val
|
||||||
:on-change #(reset! val (-> % .-target .-value))}]]])))
|
:on-change #(reset! val (-> % .-target .-value))}]]])))
|
||||||
|
|
||||||
|
(defn timer-component []
|
||||||
|
(let [seconds-elapsed (atom 0)]
|
||||||
|
(fn []
|
||||||
|
(js/setTimeout #(swap! seconds-elapsed inc) 1000)
|
||||||
|
[:div
|
||||||
|
"Seconds Elapsed: " @seconds-elapsed])))
|
||||||
|
|
||||||
(defn render-simple []
|
(defn render-simple []
|
||||||
(cloact/render-component [simple-component]
|
(cloact/render-component [simple-component]
|
||||||
(.-body js/document)))
|
(.-body js/document)))
|
||||||
@ -156,9 +163,9 @@
|
|||||||
[:h2 "Introduction to Cloact"]
|
[:h2 "Introduction to Cloact"]
|
||||||
|
|
||||||
[:p "Cloact provides a minimalistic interface between ClojureScript
|
[:p "Cloact provides a minimalistic interface between ClojureScript
|
||||||
and React. It allows you to define React components using nothing but
|
and React. It allows you to define React components using nothing
|
||||||
plain ClojureScript functions, that describe your UI using a
|
but plain ClojureScript functions, that describe your UI using a
|
||||||
Hiccup-like syntax."]
|
Hiccup-like syntax."]
|
||||||
|
|
||||||
[:p "A very basic component may look something like this: "]
|
[:p "A very basic component may look something like this: "]
|
||||||
[demo-component {:comp simple-component
|
[demo-component {:comp simple-component
|
||||||
@ -204,12 +211,17 @@ Hiccup-like syntax."]
|
|||||||
[demo-component {:comp local-state
|
[demo-component {:comp local-state
|
||||||
:defs [:ns :local-state]}]
|
:defs [:ns :local-state]}]
|
||||||
|
|
||||||
[:p "This example also uses another feature of Cloact: a component
|
[:p "The previous example also uses another feature of Cloact: a component
|
||||||
function can return another function, that is used to do the actual
|
function can return another function, that is used to do the actual
|
||||||
rendering. It is called with the same arguments as any other
|
rendering. It is called with the same arguments as any other
|
||||||
component function. This allows you to perform some setup of newly
|
component function. This allows you to perform some setup of newly
|
||||||
created components, without resorting to React's lifecycle
|
created components, without resorting to React's lifecycle
|
||||||
events."]])
|
events."]
|
||||||
|
|
||||||
|
[:p "Here is another example, where we call setTimeout everytime
|
||||||
|
the component is rendered to update a simple clock:"]
|
||||||
|
[demo-component {:comp timer-component
|
||||||
|
:defs [:timer-component]}]])
|
||||||
|
|
||||||
(defn essential-api []
|
(defn essential-api []
|
||||||
[:div
|
[:div
|
||||||
|
Loading…
x
Reference in New Issue
Block a user