dioxus/examples/link.rs
2023-09-17 20:00:22 -05:00

60 lines
1.2 KiB
Rust

use dioxus::prelude::*;
use dioxus_router::prelude::*;
fn main() {
dioxus_desktop::launch(App);
}
#[component]
fn App(cx: Scope) -> Element {
cx.render(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(cx: Scope) -> Element {
render! {
h1 { "Your app here" }
ul {
li { Link { to: Route::Home {}, "home" } }
li { Link { to: Route::Settings {}, "settings" } }
}
Outlet::<Route> {}
}
}
#[component]
fn Home(cx: Scope) -> Element {
render!(h1 { "Home" })
}
#[component]
fn Settings(cx: Scope) -> Element {
render!(h1 { "Settings" })
}