mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-12-29 22:13:08 +00:00
31 lines
948 B
Rust
31 lines
948 B
Rust
//! Example: Webview Renderer
|
|
//! -------------------------
|
|
//!
|
|
//! This example shows how to use the dioxus_webview crate to build a basic desktop application.
|
|
//!
|
|
//! Under the hood, the dioxus_webview crate bridges a native Dioxus VirtualDom with a custom prebuit application running
|
|
//! in the webview runtime. Custom handlers are provided for the webview instance to consume patches and emit user events
|
|
//! into the native VDom instance.
|
|
//!
|
|
//! Currently, NodeRefs won't work properly, but all other event functionality will.
|
|
|
|
use dioxus::prelude::*;
|
|
|
|
fn main() {
|
|
dioxus::webview::launch(App);
|
|
}
|
|
|
|
static App: FC<()> = |cx| {
|
|
let (count, set_count) = use_state(&cx, || 0);
|
|
|
|
cx.render(rsx! {
|
|
div {
|
|
h1 { "Dioxus Desktop Demo" }
|
|
p { "Count is {count}" }
|
|
button {
|
|
"Click to increment"
|
|
onclick: move |_| set_count(count + 1)
|
|
}
|
|
}
|
|
})
|
|
};
|