signals.rs 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. use dioxus::prelude::*;
  2. use std::time::Duration;
  3. fn main() {
  4. dioxus_desktop::launch(app);
  5. }
  6. fn app(cx: Scope) -> Element {
  7. let running = dioxus_signals::use_signal(cx, || true);
  8. let mut count = dioxus_signals::use_signal(cx, || 0);
  9. let saved_values = dioxus_signals::use_signal(cx, || vec![0]);
  10. use_future!(cx, || async move {
  11. loop {
  12. if running.value() {
  13. count += 1;
  14. }
  15. tokio::time::sleep(Duration::from_millis(400)).await;
  16. }
  17. });
  18. cx.render(rsx! {
  19. h1 { "High-Five counter: {count}" }
  20. button { onclick: move |_| count += 1, "Up high!" }
  21. button { onclick: move |_| count -= 1, "Down low!" }
  22. button { onclick: move |_| running.toggle(), "Toggle counter" }
  23. button { onclick: move |_| saved_values.push(count.value()), "Save this value" }
  24. // We can do boolean operations on the current signal value
  25. if count.value() > 5 {
  26. rsx!{ h2 { "High five!" } }
  27. }
  28. // We can cleanly map signals with iterators
  29. for value in saved_values.read().iter() {
  30. h3 { "Saved value: {value}" }
  31. }
  32. })
  33. }