Utilizzo dei Motori di Template

Salvo non include alcun motore di template integrato, poiché le preferenze per lo stile dei motori di template variano da persona a persona.

Fondamentalmente, un motore di template si riduce a: dati + template = stringa.

Pertanto, purché la stringa finale possa essere renderizzata, qualsiasi motore di template può essere supportato.

Ad esempio, il supporto per 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;
}

Nota: Per progetti non particolarmente complessi, consigliamo vivamente di adottare un approccio di separazione tra frontend e backend. Utilizza framework UI più flessibili e con un ecosistema ricco (come React, Vue, Svelte, ecc.) per costruire il frontend, mentre Salvo funge da servizio API backend. Questo approccio porta a una maggiore efficienza di sviluppo, responsabilità più chiare tra frontend e backend e si allinea meglio con le tendenze moderne dello sviluppo di applicazioni web.