dioxus/examples/scroll_to_top.rs

34 lines
770 B
Rust
Raw Normal View History

2023-03-24 16:32:42 +00:00
use dioxus::prelude::*;
fn main() {
dioxus_desktop::launch(app);
}
fn app(cx: Scope) -> Element {
let header_element = use_ref(cx, || None);
cx.render(rsx!(
div {
h1 {
onmounted: move |cx| {
header_element.set(Some(cx.inner().clone()));
},
"Scroll to top example"
}
for i in 0..100 {
div { "Item {i}" }
}
button {
onclick: move |_| {
if let Some(header) = header_element.read().as_ref() {
_ = header.scroll_to(ScrollBehavior::Smooth);
2023-03-24 16:32:42 +00:00
}
},
"Scroll to top"
}
}
))
}