selector.rs 550 B

123456789101112131415161718192021222324252627282930
  1. #![allow(non_snake_case)]
  2. use dioxus::prelude::*;
  3. use dioxus_signals::*;
  4. fn main() {
  5. dioxus_desktop::launch(app);
  6. }
  7. fn app(cx: Scope) -> Element {
  8. let signal = use_signal(cx, || 0);
  9. let doubled = use_selector(cx, move || signal * 2);
  10. render! {
  11. button {
  12. onclick: move |_| *signal.write() += 1,
  13. "Increase"
  14. }
  15. Child {
  16. signal: doubled
  17. }
  18. }
  19. }
  20. #[inline_props]
  21. fn Child(cx: Scope, signal: ReadOnlySignal<usize>) -> Element {
  22. render! {
  23. "{signal}"
  24. }
  25. }