2021-07-02 05:30:52 +00:00
|
|
|
//! Example: Children
|
|
|
|
//! -----------------
|
|
|
|
//!
|
2021-10-24 17:30:36 +00:00
|
|
|
//! Dioxus supports passing children in from the parent. These children are allocated in the parent and just passed
|
|
|
|
//! into the child. Components that pass in children may not be safely memoized, though in practice it's rare for a
|
2021-07-02 05:30:52 +00:00
|
|
|
//! change in a parent to not result in a different set of children.
|
|
|
|
//!
|
|
|
|
//! In Dioxus, children can *only be a list*. Unlike React, you cannot pass in functions or arbitrary data. This is
|
2021-10-24 17:30:36 +00:00
|
|
|
//! partially a limitation of having static types, but is rather intentional to encourage the use of attributes where
|
2021-07-02 05:30:52 +00:00
|
|
|
//! arbitrary child data might normally be used. Check out the `function driven children` example for how to adopt your
|
2021-10-24 17:30:36 +00:00
|
|
|
//! React pattern to Dioxus' semantics.
|
2021-07-02 05:30:52 +00:00
|
|
|
//!
|
|
|
|
//! Dioxus will let you use the `children` method more than once - and it's semantically *okay* - but you'll likely
|
|
|
|
//! ruin your page if you try to clone elements in this way. Under the hood, Dioxus shares a "mounted ID" for each node,
|
|
|
|
//! and mounting the same VNode in two places will overwrite the first mounted ID. This will likely lead to dead elements.
|
|
|
|
//!
|
|
|
|
//! In the future, this might become a runtime error, so consider it an error today.
|
|
|
|
|
|
|
|
use dioxus::prelude::*;
|
|
|
|
|
2022-01-02 23:35:38 +00:00
|
|
|
fn Example(cx: Scope) -> Element {
|
2021-07-02 05:30:52 +00:00
|
|
|
cx.render(rsx! {
|
|
|
|
div {
|
|
|
|
Banner {
|
|
|
|
p { "Some Content1" }
|
|
|
|
}
|
|
|
|
Banner {
|
|
|
|
p { "Some Content2" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
2022-01-02 23:35:38 +00:00
|
|
|
}
|
2021-07-02 05:30:52 +00:00
|
|
|
|
2022-01-02 23:35:38 +00:00
|
|
|
#[derive(Props)]
|
|
|
|
struct BannerProps {
|
|
|
|
children: Element<'a>,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn Banner(cx: Scope) -> Element {
|
2021-07-02 05:30:52 +00:00
|
|
|
cx.render(rsx! {
|
|
|
|
div {
|
|
|
|
h1 { "This is a great banner!" }
|
2022-01-02 23:35:38 +00:00
|
|
|
div { class: "content", &cx.props.children }
|
2021-07-02 05:30:52 +00:00
|
|
|
footer { "Wow, what a great footer" }
|
|
|
|
}
|
|
|
|
})
|
2022-01-02 23:35:38 +00:00
|
|
|
}
|