RSX
This macro is the recommended way to describe a ui, it is a div that holds multiple elements
fn app() -> Element {
rsx! {
button { "click me" }
text { "This is some text" }
}
}
rsx!
is really just a div, so you can just do something likersx! {
id: "root", class: "root",
button { "click me" }
text { "This is some text" }
}
Child values
If you want to add more children to values then just simply express it like a rsx!
fn app() -> Element {
let x = 69;
rsx! {
div {
text { "the number is {x}, Nice!" }
}
}
}
Formatted text
fn app() -> Element {
let x = 69;
rsx! {
text { "the number is {x}, Nice!" }
}
}
You can also do expressions after the string
text { "the number is {}, Nice!", x }
For loops
fn app() -> Element {
rsx! {
for (i in 0..5) { // () are required
text { "{i}" }
}
}
}
Attribute
You can change the element's struct fields by just providing some attributes before the children
fn app() -> Element {
rsx! {
text { class: "my_text" }
}
}
Type assignment
In special elements like data_holder
You can specify what type
the element holds. It would act like my_fn::<Type>()
fn app() -> Element {
rsx! {
// assign the type u32
data_holder as u32 { id: "count" }
}
}
Handler functions
Instead of closures which are tricky to work with on structs, We use Handler
, It's basically a closure wrapped with a Arc<Mutex<T>>
fn app() -> Element {
rsx! {
button {
on_click: fn(btn: &mut Button, event, document) {
// do something
}
}
}
}