欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

express框架通過ejs模板渲染輸出頁面實(shí)例分析

 更新時(shí)間:2023年05月15日 09:37:45   作者:Teacher_Tian_2019  
這篇文章主要介紹了express框架通過ejs模板渲染輸出頁面的方法,結(jié)合實(shí)例形式分析了express框架使用ejs模版引擎渲染輸出的相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下

1、前言

  上一節(jié)的get請(qǐng)求中,處理函數(shù)通過res.send返回了一段html代碼,這讓我們很興奮。我們終于可以給用戶返回html頁面了。
  當(dāng)時(shí)例子是這么寫的,只要在send中傳入一些html格式的字符串即可。

// get router
router.get('/', function(req, res, next) {
    res.send('<p>這是get請(qǐng)求/system返回的資源</p>')
});

  那我問個(gè)問題,如果我想返回給用戶的是一張學(xué)生的成績信息怎么辦?其實(shí)可以這樣寫:

router.get('/', function(req, res, next) {
    res.send('<div>2004年高考成績查詢(張三)</div><table><tr><td>1</td><td>語文</td><td>135</td></tr><tr><td>2</td><td>數(shù)學(xué)</td><td>131</td></tr><tr><td>3</td><td>英語</td><td>96</td></tr><tr><td>4</td><td>理科綜合</td><td>243</td></tr></table>')
});

  這樣也是沒啥毛病吧!但最大的問題來了,一般情況數(shù)據(jù)都是動(dòng)態(tài)的從數(shù)據(jù)庫獲取或計(jì)算得來的,在輸出到頁面時(shí)字符串的拼接需要通過字符串(如html標(biāo)簽)和變量組成的。但這樣的拼接工作相當(dāng)?shù)馁M(fèi)勁而且容易出錯(cuò),出錯(cuò)后有時(shí)候也不容易排查。
  繞了這么久,終于可以引出本文的主題了——ejs模板。目前,我先只能這么給大家解釋ejs模板是個(gè)什么東東吧:

  1. 它的內(nèi)容是以html標(biāo)簽為基礎(chǔ)的,只不過加入了一些占位符(如${name})、簡單ejs邏輯(如<% if(…) { %> 等)
  2. 它的后綴名可以定義為.html,但初期請(qǐng)各位記住它的文件后綴名就是.ejs吧
  3. 簡單的json數(shù)據(jù) 和 ejs模板文件,在res.render方法執(zhí)行后,就能將數(shù)據(jù)套入到模板中,完成動(dòng)態(tài)網(wǎng)頁的輸出。

  文字描述內(nèi)容就到這里,后邊的小節(jié)基本上是以代碼+代碼注釋進(jìn)行說明,應(yīng)該是更加容易理解了。

2、創(chuàng)建ejs模板文件

  在views目錄下創(chuàng)建文件,命名為score.ejs,代碼如下:

<!DOCTYPE html>
<html>
  <head>
    <title>成績單</title>
    <link rel='stylesheet' href='/stylesheets/style.css' />
  </head>
  <body>
    <div><%= year %>年高考成績查詢(張三)</div>
    <table>
        <% scores.forEach(function(item,index){ %>
            <tr><td><%= index %></td><td><%=item.course %></td><td><%=item.score %></td></tr>
        <% }); %>
    </table>
  </body>
</html>

3、修改router文件,通過模板輸出響應(yīng)內(nèi)容

  注意,我說的router文件,就是上篇文章中說的system.js哈。找到router.get部分,修改之前是這樣的:

router.get('/', function(req, res, next) {
    res.send('<p>這是get請(qǐng)求/system返回的資源</p>')
});

修改之后是:

router.get('/', function(req, res, next) {
    //準(zhǔn)備好的數(shù)據(jù),真實(shí)的情形是從數(shù)據(jù)庫中得來的
    var data = {
        year:2004,
        scores:[
            {
                course:"語文",
                score: 135
            },
            {
                course:"數(shù)學(xué)",
                score:131
            },
            {
                course:"英語",
                score:96
            },
            {
                course:"理科綜合",
                score:243
            }
        ]
    };
    //通過模板和數(shù)據(jù)渲染頁面
    res.render('score', data);
});

4、就這么簡單,啟動(dòng)服務(wù),驗(yàn)證

  預(yù)期的結(jié)果如下,你搞成功了嗎?
在這里插入圖片描述

5、補(bǔ)充說明

  是不是覺得成功來得很容易?
  其實(shí)不然,你的成功來自于最初你使用了express-generator腳手架,還記得我在快速搭建Express開發(fā)系統(tǒng) 提到的命令:

npx express-generator --view ejs

嗎?它為我們做了多工作,具體表現(xiàn)在以下方面(看圖):
在這里插入圖片描述
  這兩句分別為我們指定了模板文件存放的路徑,和指定ejs為模板引擎。

6、寫在最后

  其實(shí)ejs模板文件中的語法是非常復(fù)雜的,例如條件、循環(huán)、html富文本輸出……等,建議需要深入研究的同學(xué)可以通過這個(gè)鏈接去了解一下。
  在下一篇文章中,我會(huì)將本節(jié)的表格美化一下,加上一些bootstrap樣式。因?yàn)槲以谧畛跚昂蠖送瑫r(shí)開發(fā)時(shí),也遇到過一些小問題,所以我想是值得一講的。ok,就到這里,期待下次見。

補(bǔ)充:express.render渲染ejs顯示源碼的問題解決方法

筆者在測(cè)試express框架的時(shí)候遇到的ejs顯示源碼的問題,檢查之后才發(fā)現(xiàn)在設(shè)置response的head的時(shí)候,在app.all('*', function(req, res, next)中加了一句res.header("Content-Type", "application/json;charset=utf-8");,將其注釋掉,重啟nodejs服務(wù)器,輸入路由后在瀏覽器按快捷鍵Ctrl+F5即可。

相關(guān)文章

  • 一些可能會(huì)用到的Node.js面試題

    一些可能會(huì)用到的Node.js面試題

    這篇文章主要介紹了一些可能會(huì)用到的Node.js面試題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下
    2019-06-06
  • npm全局模塊卸載及默認(rèn)安裝目錄修改方法

    npm全局模塊卸載及默認(rèn)安裝目錄修改方法

    今天小編就為大家分享一篇npm全局模塊卸載及默認(rèn)安裝目錄修改方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 分享五個(gè)Node.js開發(fā)的優(yōu)秀實(shí)踐?

    分享五個(gè)Node.js開發(fā)的優(yōu)秀實(shí)踐?

    這篇文章主要介紹了分享五個(gè)Node.js開發(fā)的優(yōu)秀實(shí)踐,文章圍繞主題展開詳細(xì)的分享內(nèi)容,需要的小伙伴可以參考一下,希望對(duì)你的工作有所幫助
    2022-04-04
  • node快速搭建后臺(tái)的實(shí)現(xiàn)步驟

    node快速搭建后臺(tái)的實(shí)現(xiàn)步驟

    本文主要介紹了node快速搭建后臺(tái),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • node.js調(diào)用C++函數(shù)的方法示例

    node.js調(diào)用C++函數(shù)的方法示例

    這篇文章主要介紹了node.js調(diào)用C++函數(shù)的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • Nest 復(fù)雜查詢示例解析

    Nest 復(fù)雜查詢示例解析

    這篇文章主要為大家介紹了Nest 復(fù)雜查詢示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Node.js利用console輸出日志文件的方法示例

    Node.js利用console輸出日志文件的方法示例

    本篇文章主要介紹了Node.js利用console輸出日志文件的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • 使用upstart把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)實(shí)例

    使用upstart把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)實(shí)例

    這篇文章主要介紹了使用upstart把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)實(shí)例,需要的朋友可以參考下
    2014-06-06
  • node.js [superAgent] 請(qǐng)求使用示例

    node.js [superAgent] 請(qǐng)求使用示例

    這篇文章主要介紹了node.js [superAgent] 請(qǐng)求使用示例,分別給大家匯總了post請(qǐng)求、get請(qǐng)求、delete請(qǐng)求和put請(qǐng)求的示例,推薦給大家,希望大家能夠喜歡。
    2015-03-03
  • nodejs aes 加解密實(shí)例

    nodejs aes 加解密實(shí)例

    今天小編就為大家分享一篇nodejs aes 加解密實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10

最新評(píng)論