Usando Mecanismos de Modelo

O Salvo não inclui nenhum mecanismo de modelo integrado, pois as preferências por estilos de mecanismos de modelo variam de pessoa para pessoa.

Em sua essência, um mecanismo de modelo é simplesmente: dados + modelo = string.

Portanto, desde que a string final possa ser renderizada, qualquer mecanismo de modelo pode ser suportado.

Por exemplo, suporte para 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: Para projetos que não são particularmente complexos, recomendamos fortemente a adoção de uma abordagem de separação entre frontend e backend. Use frameworks de UI mais flexíveis e com ecossistema rico (como React, Vue, Svelte, etc.) para construir o frontend, com o Salvo atuando como serviço de API backend. Essa abordagem resulta em maior eficiência de desenvolvimento, responsabilidades mais claras entre frontend e backend e melhor alinhamento com as tendências modernas de desenvolvimento de aplicações web.