EJS模板引擎

来源:http://www.cnblogs.com/xiaohuochai/archive/2017/06/15/7011594.html
-Advertisement-
Play Games

前面的話 nodejs的模板引擎有很多, EJS是比較簡單和容易上手的。本文將詳細介紹EJS 概述 EJS是一個簡單高效的模板語言,通過數據和模板,可以生成HTML標記文本。可以說EJS是一個JavaScript庫,EJS可以同時運行在客戶端和伺服器端,客戶端安裝直接引入文件即可,伺服器端用npm包 ...


前面的話

  nodejs的模板引擎有很多, EJS是比較簡單和容易上手的。本文將詳細介紹EJS

 

概述

  EJS是一個簡單高效的模板語言,通過數據和模板,可以生成HTML標記文本。可以說EJS是一個JavaScript庫,EJS可以同時運行在客戶端和伺服器端,客戶端安裝直接引入文件即可,伺服器端用npm包安裝

【安裝】

  ejs可以配合express框架使用,或直接在node中/瀏覽器中使用

$ npm install ejs

【特點】

  1、快速編譯和渲染

  2、簡單的模板標簽

  3、自定義標記分隔符

  4、支持文本包含

  5、支持瀏覽器端和伺服器端

  6、模板靜態緩存

  7、支持express視圖系統

 

用法

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<div id="div1"></div>
<script src="ejs.min.js"></script>
<script>
    var html = ejs.render('<%=123 %>','');
    document.getElementById('div1').innerHTML = html;
</script>
</body>
</html>

 

方法

【ejs.compile(str,[option])】

  編譯字元串得到模板函數,參數如下

str:需要解析的字元串模板
option:配置選項
var template = ejs.compile('<%=123 %>');
var result = template();
console.log(result);//123

【ejs.render(str,data,[option])】

  直接渲染字元串並生成html,參數如下

str:需要解析的字元串模板
data:數據
option:配置選項
var result = ejs.render('<%=123 %>');
console.log(result);//123

  兩個函數包括的配置選項參數options如下:

cache 緩存編譯後的函數(ejs.compile(..) ,需要 filename參數作為緩存的key
filename 用於緩存的key,和include
context 函數的執行上下文
compileDebug 輸出compile的信息來跟蹤調試
client 返回編譯後的函數
delimiter <% .. %> 指這裡的%
debug 輸出ejs.compile()得到函數的函數體
strict ejs.compile()返回的函數是否執行在嚴格模式
_with 是否使用 with(){..} 來訪問本地變數
localsName 保存本地變數的對象名,預設為locals
rmWhitespace 移除多餘空格

 

常用標簽

【js】

  所有使用 <% %> 括起來的內容都會被編譯成 Javascript,可以在模版文件中像寫js一樣Coding

//test.ejs
<% var a = 123 %>
<% console.log(a); %>

//test.js
var ejs = require('ejs');
var fs = require('fs');
var data = fs.readFileSync('test.ejs');
var result = ejs.render(data.toString());
console.log(result);//123

  或者,像下麵這樣寫

var ejs = require('ejs');
var result = ejs.render('<% var a = 123 %><%console.log(a); %>');
console.log(result);//123

【變數】

  用<%=...%>輸出變數,變數若包含 '<' '>' '&'等字元會被轉義

var ejs = require('ejs');
var result = ejs.render('<%=a%>',{a:'<div>123</div>'});
console.log(result);//&lt;div&gt;123&lt;/div&gt;

  如果不希望變數值的內容被轉義,那就這麼用<%-... %>輸出變數

var ejs = require('ejs');
var result = ejs.render('<%-a%>',{a:'<div>123</div>'});
console.log(result);//<div>123</div>

【註釋】

  用<%# some comments %>來註釋,不執行不輸出

【include】

  include 可以引用絕對路徑或相對路徑的模板文件

//test.ejs
<% var a = 123 %>
<% console.log(a); %>
//test.js
var ejs = require('ejs');var result = ejs.render('<% include test.ejs %>');
//throw new Error('`include` use relative path requires the \'filename\' option.');
console.log(result);

  由上面的提示可知,使用相對路徑時,必須設置'filename'選項

//test.ejs
<% var a = 123 %>
<% console.log(a); %>
//test.js
var ejs = require('ejs');var result = ejs.render('<% include test.ejs %>',{filename:'test.ejs'});
console.log(result);//123

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 對於做網站的人來說,常常需要做js跳轉,對於做seo的人來說,尤其是有興趣涉足黑帽seo的人員,js跳轉更是家常便飯。那麼,js跳轉有哪些類型呢,今天小編在這裡給大家總結了一下大概的js跳轉種類,希望能對大家有所幫助。 一、從一個頁面跳轉到另一個頁面1、在本視窗中跳轉到另一個頁面 <script t ...
  • 1、 通過在IE中載入adobe pdf reader 插件 進行直接列印和列印的配置(推薦) <body> <object id="pdf1" width="1000px" height="400px" classid="clsid:CA8A9780-280D-11CF-A24D-44455354 ...
  • 換行, 單標簽 分割線,水平線 段落, 有換行功能, 而且行距會比普通換行要寬. 通用分組, 看上去和是完全一樣的. 但是br是單標簽, 雙標簽是可以控制內容的屬性的. 頁邊縮進. 引用整塊文字的段落, 多用於轉換場景意境的引用. 多用於正規書籍出版, 或者微信平臺美化. 按照編輯器文本的排版顯示排... ...
  • 上一面講述了向場景中添加物體對象。這一篇準備把每個功能點細細的講述一遍,一方面是為了加深自己的理解。另一方面希望能夠 幫助到有需要的人。 一、在學習WEBGL的時候,你應該先瞭解要創建一個WebGL程式需要哪些步驟。就跟弄梅菜扣肉一樣,需要哪些步驟。 初始化WebGL繪圖上下文 初始化著色器程式 建 ...
  • 文本樣式 列表 無序號列表: 有序號列表: ...
  • 模塊化就是通過每一個js里封裝一個方法:用exports將他輸出, 在下一個js用require的方法載入js時就會將方法輸出。然後在主頁面引入require.js; 模塊化基本寫法: require:載入一個模塊,後面跟的是一個js文件名 exports:輸出 module:模塊 舉一個例子: 第 ...
  • 比如我們定義一個TouchableOpacity點擊事件,該方法需要接收一個參數值,如下 那麼在TouchableOption組件的onPress屬性中應該這樣寫: 或者 ...
  • 1、下載npm包 官網下載npm安裝包,https://nodejs.org/en/,左邊是穩定版右邊是最新版。 2、解壓,創建鏈接 將壓縮包解壓到/opt(一般軟體放在該目錄)目錄下。可以看到bin目錄下有兩個可執行文件node和npm,在/usr/local/bin中創建該文件的鏈接 然後使用n ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...