mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-10 14:44:12 +00:00
60 lines
1.2 KiB
Rust
60 lines
1.2 KiB
Rust
use dioxus::prelude::*;
|
|
use dioxus_router::prelude::*;
|
|
|
|
fn main() {
|
|
launch_desktop(App);
|
|
}
|
|
|
|
#[component]
|
|
fn App() -> Element {
|
|
rsx! (
|
|
div {
|
|
p { a { href: "http://dioxuslabs.com/", "Default link - links outside of your app" } }
|
|
p {
|
|
a {
|
|
href: "http://dioxuslabs.com/",
|
|
prevent_default: "onclick",
|
|
onclick: |_| println!("Hello Dioxus"),
|
|
"Custom event link - links inside of your app"
|
|
}
|
|
}
|
|
}
|
|
div { Router::<Route> {} }
|
|
)
|
|
}
|
|
|
|
#[derive(Routable, Clone)]
|
|
#[rustfmt::skip]
|
|
enum Route {
|
|
#[layout(Header)]
|
|
#[route("/")]
|
|
Home {},
|
|
#[route("/settings")]
|
|
Settings {},
|
|
}
|
|
|
|
#[component]
|
|
fn Header() -> Element {
|
|
rsx! {
|
|
h1 { "Your app here" }
|
|
ul {
|
|
li {
|
|
Link { to: Route::Home {}, "home" }
|
|
}
|
|
li {
|
|
Link { to: Route::Settings {}, "settings" }
|
|
}
|
|
}
|
|
Outlet::<Route> {}
|
|
}
|
|
}
|
|
|
|
#[component]
|
|
fn Home() -> Element {
|
|
rsx!( h1 { "Home" } )
|
|
}
|
|
|
|
#[component]
|
|
fn Settings() -> Element {
|
|
rsx!( h1 { "Settings" } )
|
|
}
|