mirror of
https://github.com/DioxusLabs/dioxus
synced 2025-01-26 19:45:10 +00:00
73047fe956
This commit solves the memoization , properly memoizing properties that don't have any generic parameters. This is a rough heuristic to prevent non-static lifetimes from creeping into props and breaking our minual lifetime management. Props that have a generic parameter are opted-out of the `partialeq` requirement and props *without* lifetimes must implement partialeq. We're going to leave manual disabling of memoization for future work.
65 lines
2.2 KiB
Rust
65 lines
2.2 KiB
Rust
use dioxus_core as dioxus;
|
|
use dioxus_core::prelude::*;
|
|
use dioxus_web::WebsysRenderer;
|
|
|
|
fn main() {
|
|
// wasm_logger::init(wasm_logger::Config::new(log::Level::Debug));
|
|
console_error_panic_hook::set_once();
|
|
|
|
log::info!("hello world");
|
|
wasm_bindgen_futures::spawn_local(WebsysRenderer::start(App));
|
|
}
|
|
|
|
static App: FC<()> = |ctx| {
|
|
let (val, set_val) = use_state(&ctx, || "asd".to_string());
|
|
|
|
ctx.render(rsx! {
|
|
div { class: "max-w-lg max-w-xs bg-blue-800 shadow-2xl rounded-lg mx-auto text-center py-12 mt-4 rounded-xl"
|
|
div { class: "container py-5 max-w-md mx-auto"
|
|
h1 { class: "text-gray-200 text-center font-extrabold -mt-3 text-3xl",
|
|
"Text Input Example"
|
|
}
|
|
div { class: "mb-4"
|
|
input {
|
|
placeholder: "Username"
|
|
class: "shadow appearance-none rounded w-full py-2 px-3 text-gray-700 leading-tight focus:outline-none focus:shadow-outline"
|
|
id: "username"
|
|
type: "text"
|
|
value: "{val}"
|
|
oninput: move |evet| set_val(evet.value())
|
|
}
|
|
p { "Val is: {val}" }
|
|
}
|
|
}
|
|
}
|
|
})
|
|
};
|
|
|
|
static Example: FC<()> = |ctx| {
|
|
ctx.render(rsx! {
|
|
div { class: "max-w-lg max-w-xs bg-blue-800 shadow-2xl rounded-lg mx-auto text-center py-12 mt-4 rounded-xl"
|
|
div { class: "container py-5 max-w-md mx-auto"
|
|
h1 { class: "text-gray-200 text-center font-extrabold -mt-3 text-3xl",
|
|
"Text Input Example"
|
|
}
|
|
UserInput {}
|
|
}
|
|
}
|
|
})
|
|
};
|
|
|
|
static UserInput: FC<()> = |ctx| {
|
|
let (val, set_val) = use_state(&ctx, || "asd".to_string());
|
|
|
|
rsx! { in ctx,
|
|
div { class: "mb-4"
|
|
input { class: "shadow appearance-none rounded w-full py-2 px-3 text-gray-700 leading-tight focus:outline-none focus:shadow-outline"
|
|
placeholder: "Username"
|
|
id: "username"
|
|
type: "text"
|
|
oninput: move |evet| set_val(evet.value())
|
|
}
|
|
p { "Val is: {val}" }
|
|
}
|
|
}
|
|
};
|