手把手教你用axum開發(fā)博客系統(tǒng)二:使用模板引擎

現(xiàn)在的大部分web項目都是前后端分離的铭段,但是霎箍,對于一個后端開發(fā)來說祈匙,額外去學(xué)習(xí)vue,react等前端框架還是需要投入不少的時間吐限,雖然說多學(xué)點總沒壞處鲜侥,但是對于僅有幾個頁面的簡單項目(比如本教程的個人博客系統(tǒng)),還是更推薦使用語言自帶的模板引擎诸典;


選擇模板引擎

crates.io上來看描函,template-engine 分類下,下載量較多的有

  • tinytemplate
  • handlebars
  • tera
  • askama

筆者最先接觸的是askama, 使用下來也比較接近其他語言的模板引擎狐粱,所以本教程就使用askama 作為示例舀寓;

創(chuàng)建第一個模板并發(fā)布


  1. 添加項目依賴
...
[dependencies.askama]
version = "0.12.1"
features = ["with-axum"]
[dependencies.askama_axum]
version = "0.4.0"
...
  1. 創(chuàng)建第一個模板

1). askama讀取模板文件的根路徑默認為根目錄下的 templates 目錄(可通過配置文件配置,在此我們使用默認配置)肌蜻,
2). 模板路徑為 templates/index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    Hello,{{name}}
</body>
</html>
  1. 在rust中導(dǎo)入模板

    ...
    use askama_axum::Template;
    
    #[derive(Template,Debug)]
    #[template(path="index.html")]
    struct IndexTemplate{
        name:String,
    }
    ...
    
  2. 將模板通過axum路由返回并渲染到頁面

...
// 創(chuàng)建路由handler
async fn index() -> Html<String> {
    let index = IndexTemplate {
        name: "World".to_string(),
    };
    let s = index.render().unwrap().into();
    s
}
...

完整代碼:

use askama_axum::Template;
use axum::{response::Html, routing::get, Router};

#[derive(Debug, Template)]
#[template(path = "index.html")]
pub struct IndexTemplate {
    name: String,
}

#[tokio::main]
async fn main() {
    let app = Router::new().route("/", get(index));
    let tcp_listener = tokio::net::TcpListener::bind("127.0.0.1:3000")
        .await
        .unwrap();
    axum::serve(tcp_listener, app).await.expect("啟動失敗");
}

async fn index() -> Html<String> {
    let index = IndexTemplate {
        name: "World".to_string(),
    };
    let s = index.render().unwrap().into();
    s
}

瀏覽器訪問http://localhost:3000 可看到 Hello,World

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末互墓,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蒋搜,更是在濱河造成了極大的恐慌篡撵,老刑警劉巖判莉,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異育谬,居然都是意外死亡券盅,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人尸饺,你說我怎么就攤上這事〕握撸” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我花鹅,道長,這世上最難降的妖魔是什么磕潮? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任翠胰,我火速辦了婚禮容贝,結(jié)果婚禮上自脯,老公的妹妹穿的比我還像新娘。我一直安慰自己斤富,他們只是感情好膏潮,可當(dāng)我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著满力,像睡著了一般焕参。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上油额,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天叠纷,我揣著相機與錄音,去河邊找鬼潦嘶。 笑死涩嚣,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的掂僵。 我是一名探鬼主播航厚,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼锰蓬!你這毒婦竟也來了幔睬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤芹扭,失蹤者是張志新(化名)和其女友劉穎麻顶,沒想到半個月后赦抖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡澈蚌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年摹芙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宛瞄。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡浮禾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出份汗,到底是詐尸還是另有隱情盈电,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布杯活,位于F島的核電站匆帚,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏旁钧。R本人自食惡果不足惜吸重,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望歪今。 院中可真熱鬧嚎幸,春花似錦、人聲如沸寄猩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽田篇。三九已至替废,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間泊柬,已是汗流浹背椎镣。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留兽赁,地道東北人状答。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像闸氮,于是被迫代替她去往敵國和親剪况。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容