Template-Engines verwenden

Salvo enthält keine integrierte Template-Engine, da die Vorlieben für Template-Engine-Stile von Person zu Person unterschiedlich sind.

Im Kern ist eine Template-Engine einfach: Daten + Vorlage = Zeichenkette.

Daher kann jede Template-Engine unterstützt werden, solange die endgültige Zeichenkette gerendert werden kann.

Beispielsweise die Unterstützung für askama:

main.rs
Cargo.toml
templates/hello.html
use askama::Template;
use salvo::prelude::*;

#[derive(Template)]
#[template(path = "hello.html")]
struct HelloTemplate<'a> {
    name: &'a str,
}

#[handler]
async fn hello(req: &mut Request, res: &mut Response) {
    let hello_tmpl = HelloTemplate {
        name: req.param::<&str>("name").unwrap_or("World"),
    };
    res.render(Text::Html(hello_tmpl.render().unwrap()));
}

#[tokio::main]
async fn main() {
    tracing_subscriber::fmt().init();

    let router = Router::with_path("{name}").get(hello);
    let acceptor = TcpListener::new("0.0.0.0:8698").bind().await;
    Server::new(acceptor).serve(router).await;
}

Hinweis: Für Projekte, die nicht besonders komplex sind, empfehlen wir dringend einen Ansatz mit Trennung von Frontend und Backend. Verwenden Sie flexiblere und ökosystemreichere UI-Frameworks (wie React, Vue, Svelte usw.) für den Aufbau des Frontends, während Salvo als Backend-API-Dienst dient. Dieser Ansatz führt zu höherer Entwicklungseffizienz, klareren Verantwortlichkeiten zwischen Frontend und Backend und entspricht besser den Trends der modernen Webanwendungsentwicklung.