全代码
#![allow(non_snake_case)]
use dioxus::prelude::*;
use dioxus_router::prelude::*;
#[derive(Routable, Clone)]
#[rustfmt::skip]
enum Route {
#[layout(NavBar)]
#[route("/")]
Home {},
#[nest("/blog")]
#[layout(Blog)]
#[route("/")]
BlogList {},
#[route("/post/:name")]
BlogPost { name: String },
#[end_layout]
#[end_nest]
#[end_layout]
#[nest("/myblog")]
#[redirect("/", || Route::BlogList {})]
#[redirect("/:name", |name: String| Route::BlogPost { name })]
#[end_nest]
#[route("/:..route")]
PageNotFound {
route: Vec<String>,
},
}
pub fn App() -> Element {
rsx! { Router::<Route> {} }
}
#[component]
fn NavBar() -> Element {
rsx! {
nav {
ul {
li {
Link { to: Route::Home {}, "Home" }
}
li {
Link { to: Route::BlogList {}, "Blog" }
}
}
}
Outlet::<Route> {}
}
}
#[component]
fn Home() -> Element {
rsx! { h1 { "欢迎来到 Dioxus 博客!" } }
}
#[component]
fn Blog() -> Element {
rsx! {
h1 { "博客" }
Outlet::<Route> {}
}
}
#[component]
fn BlogList() -> Element {
rsx! {
h2 { "选择一篇文章" }
ul {
li {
Link {
to: Route::BlogPost {
name: "Blog post 1".into(),
},
"阅读第一篇文章"
}
}
li {
Link {
to: Route::BlogPost {
name: "Blog post 2".into(),
},
"阅读第二篇文章"
}
}
}
}
}
#[component]
fn BlogPost(name: String) -> Element {
rsx! { h2 { "博客文章:{name}" } }
}
#[component]
fn PageNotFound(route: Vec<String>) -> Element {
rsx! {
h1 { "页面未找到" }
p { "我们非常抱歉,但您请求的页面不存在。" }
pre { color: "red", "日志:\n尝试导航到:{route:?}" }
}
}
