It builds up VDOM for not having to run too many DOM operations, but as it runs every time any change is executed, it allows for a simple programming model without message passing / callbacks / signals, just like EGUI.
The render function is called once for creating the initial web page, and then twice for each event: - once for computing the side effects of the event - once more for rendering the changes that happened by modifying the state (variables)
(in examples/demo
directory):
``` use edom; use wasmbindgen::prelude::wasmbindgen;
pub fn demo() { let mut name = "Arthur".tostring(); let mut age:f64 = 42.0; edom::wasm::render(move |mut root| { root.h1().text("My edom application"); root.div(|div| { div.text("Your name: "); div.textinput(&mut name); }); root.div(|div| { div.rangeinput(&mut age, 0.0, 120.0); div.numberinput(&mut age).min(0.0).max(120.0); div.text("age"); }); if root.button("Click each year").clicked() { age+=1.0; } root.br(); root.text(format!("Hello '{}', age {}", name, age).as_str()); }); } ```
For a more complex example check TODOMVC