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

Node.js 使用jade模板引擎的示例

 更新時(shí)間:2018年05月11日 11:19:38   作者:foruok  
本篇文章主要介紹了Node.js 使用jade模板引擎的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

“Node.js開發(fā)入門——Express安裝與使用”里,我們?cè)?jīng)使用express generator創(chuàng)建了一個(gè)HelloExpress網(wǎng)站,express工具為我們生成了基本的目錄結(jié)構(gòu)、模板、stylesheet、routers等。雖然那只是一個(gè)簡(jiǎn)單的HelloWorld類的小東西,可里面包含的內(nèi)容還是有些多了,為了更好的理解Express所支持的jade模板引擎的用法,我們這次提供一個(gè)手動(dòng)創(chuàng)建的小網(wǎng)站,可以顯示來訪者的IP,并對(duì)訪問進(jìn)行計(jì)數(shù)。

安裝jade

npm install -g jade

執(zhí)行上面的命令,全局安裝。

Visitor網(wǎng)站

第1步,在myprojects目錄下創(chuàng)建一個(gè)Visitor目錄。

第2步,把下面的代碼保存在package.json文件里:

{
 "name": "Visitor",
 "version": "0.0.0",
 "private": true,
 "dependencies": {
 "express": "~4.13.1",
 "jade": "~1.11.0",
 }
}

這個(gè)json文件描述了我們的Visitor網(wǎng)站的一些信息,最重要的部分是依賴。我們要使用express和jade。

var express = require('express');
var app = express();

var counter = 0;

// view engine setup
app.set('views', './views');
app.set('view engine', 'jade');
app.engine('jade', require('jade').__express);

app.get('/', function(req, res) {
 counter++;
 app.locals.counter = counter.toString();
 res.render('index', {ip: req.ip});
});

app.listen(3000);

app.locals.title = "Welcome to Visitor";
app.locals.counter = "0";

app.js文件是我們網(wǎng)站的入口。

第4步,創(chuàng)建一個(gè)views目錄,在里面創(chuàng)建一個(gè)模板文件index.jade,內(nèi)容如下:

doctype html
html
 head
 title= title
 body
 h1= title
 p Hello, #{ip}
 p You're the #{counter} visitor.

第5步,在Visitor目錄里執(zhí)行“npm install”,安裝依賴。

第6步,在Visitor目錄里執(zhí)行“node app.js”,啟動(dòng)網(wǎng)站。

最后呢,就可以在瀏覽器里訪問了,地址欄里輸入“http://localhost:3000”即可,刷新幾次,你可能會(huì)看到下面的界面:

這個(gè)簡(jiǎn)單的Visitor網(wǎng)站,和之前的HelloWorld、HelloExpress都不太一樣了,它有了一些動(dòng)態(tài)的內(nèi)容。接下來我們就來看看這一切是如何發(fā)生的。

express與模板引擎

我在Visitor里使用了jade模板引擎,類似的還有ejs以及很多,可以訪問這里來了解:https://github.com/joyent/node/wiki/Modules。

模板引擎使用模板文件來動(dòng)態(tài)生成HTML文件,在生成時(shí)又可以按照一定的規(guī)則將應(yīng)用程序里的數(shù)據(jù)整合進(jìn)HTML文件。這樣,我們既避免了手動(dòng)編寫HTML的繁瑣(相對(duì)使用模板而言),又能生成具有動(dòng)態(tài)內(nèi)容的網(wǎng)頁(yè)。

Express和Jade結(jié)合得比較好,我們來看看怎么配置它。

Express配置jade

Express服務(wù)器的行為可以通過一些設(shè)置選項(xiàng)來控制,這些選項(xiàng)可以通過express對(duì)象的set(setting, value)、enable(setting)和disable(setting)來設(shè)置。具體支持哪些設(shè)置,可以看這里http://expressjs.com/4x/api.html。我們的Visitor只用到了“view engine”和“views”。

“view engine”選項(xiàng)用來設(shè)置要使用的引擎,Visitor的代碼如下:

app.set('view engine', 'jade');

“views”選項(xiàng)用來設(shè)置模板文件所在目錄,Visitor的代碼如下:

app.set('views', './views');

我在這里簡(jiǎn)單的使用了相對(duì)路徑,更好的做法是使用path模塊,根據(jù)全局變量__dirname來拼接。__dirname指當(dāng)前正在執(zhí)行的腳本所在的目錄,對(duì)我們的Visitor示例來講,就是app.js所在的那個(gè)目錄。代碼可能是這樣的:

var path = require('path');
path.join(__dirname, 'views');

express默認(rèn)會(huì)根據(jù)模板文件的擴(kuò)展名來使用對(duì)應(yīng)的引擎。對(duì)于*.jade文件,express內(nèi)部會(huì)調(diào)用下面的語(yǔ)句:

app.engine('jade', require('jade').__express);

所以,我們的app.js,實(shí)際上也可以去掉這行代碼,結(jié)果是一樣的。

本地對(duì)象

我們可以在模板文件里包含動(dòng)態(tài)數(shù)據(jù),這些動(dòng)態(tài)數(shù)據(jù)來自應(yīng)用程序。我們可以使用express對(duì)象的locals對(duì)象來存儲(chǔ)本地變量。下面的代碼就存儲(chǔ)了標(biāo)題和訪問計(jì)數(shù):

app.locals.title = "Welcome to Visitor";
app.locals.counter = "0";

jade模板文件里可以直接訪問express對(duì)象的locals對(duì)象的屬性。我在app.js里設(shè)置的title和counter,在index.jade模板文件引用了它們。

現(xiàn)在我們來看這行代碼:

res.render('index', {ip: req.ip});

它調(diào)用express的Response對(duì)象的render方法來渲染模板文件,并且傳遞了一個(gè)本地對(duì)象。render方法原型:

res.render(view [, locals] [, callback])

res.render方法渲染一個(gè)view并且把渲染生成的HTML字符串發(fā)送給客戶端。res的API參考在這里http://expressjs.com/4x/api.html。

Response對(duì)象也有一個(gè)locals對(duì)象,它和app.locals的區(qū)別是,res的locals只在當(dāng)前渲染的view內(nèi)有效,而app.locals是全局的。

另外render方法的可選參數(shù)locals,也可以定義本地變量對(duì)象,傳遞給view。我在代碼里把ip傳了過去。

在jade文件里,常見的有兩種方式可以調(diào)用由應(yīng)用程序傳入的本地變量:

  1. #{表達(dá)式}
  2. 標(biāo)簽=表達(dá)式

前面的index.jade模板文件里,對(duì)于頁(yè)面標(biāo)題,我們這么用的:

title= title

title是jade用來定義HTML文檔title的標(biāo)簽。

對(duì)于body里的一級(jí)標(biāo)題,我們這么用的(h1是jade用來定義HTML一級(jí)標(biāo)題的標(biāo)簽):

h1= title

這都是屬于“標(biāo)簽=表達(dá)式”這種調(diào)用方式,這種方式通常用在一行jade代碼的開始,也就是標(biāo)簽開始的地方。而“#{表達(dá)式}”這種方式的好處是可以插入到j(luò)ade模板文件的任意地方。比如:

p Hello, #{ip}
p You're the #{counter} visitor.

我們也可以將“h1= title”修改為“h1 #{title}”,效果一樣。

jade引擎簡(jiǎn)介

jade使用一些標(biāo)簽來標(biāo)記如何生成HTML,jade模板文件看起來很不像HTML文件,但它的模板文件小而整潔。使用jade,需要了解它都支持哪些標(biāo)簽,這個(gè)可以直接去看jade-lang,那里最詳細(xì)也最權(quán)威,我們這里只介紹index.jade文件用到的那些標(biāo)簽。

關(guān)于jade,有兩篇文章不錯(cuò),可以看看,https://cnodejs.org/topic/5368adc5cf738dd6090060f2http://www.dbjr.com.cn/article/139936.htm,后面這篇文章是網(wǎng)友根號(hào)三寫的一個(gè)關(guān)于jade的系列文章的開篇,整個(gè)系列里的文章都值得一看。

HTML文檔的開始通常是文檔聲明,對(duì)應(yīng)到j(luò)ade模板文件里,就是doctype html。還有其它的文檔類型,比如xml,可以寫作doctype xml。更多請(qǐng)參考http://jade-lang.com/reference/doctype/

jade有很多標(biāo)簽,用于生成HTML對(duì)應(yīng)的標(biāo)簽。比如html對(duì)應(yīng),head對(duì)應(yīng),body對(duì)應(yīng),p對(duì)應(yīng),title對(duì)應(yīng),這也是我們的index.jade用到的所有標(biāo)簽了。通常我們?cè)贖TML里使用的標(biāo)簽寫法,去掉尖括號(hào)就成了jade里可用的標(biāo)簽,比如對(duì)應(yīng)jade里的div。

HTML標(biāo)簽往往可以設(shè)置name、id、class等屬性,在jade里,是通過tag(attr=value)這種形式表示的。比如div(class=”view-container”),又比如input(type=”checkbox”)。

關(guān)于jade標(biāo)簽,這篇文章http://www.dbjr.com.cn/article/139942.htm說得很好,請(qǐng)參考。

測(cè)試jade模板文件

一開始用jade模板,記不全它的標(biāo)簽,也經(jīng)常不知道自己的寫的模板文件生成的html文檔是否正確。還好安裝jade后,有一個(gè)命令行工具jade,可以用來驗(yàn)證模板文件。

jade的用法如下:jade [options] [dir|file …]

jade命令有很多選項(xiàng),可以執(zhí)行“jade -h”查看。要驗(yàn)證模板文件,最簡(jiǎn)單的辦法就是使用jade工具生成為html文檔。命令如下:

jade xxx.jade

執(zhí)行上面的命令,就會(huì)在當(dāng)前目錄下生成一個(gè)與模板文件同名的html文檔。不過格式很難讀,完全是一坨屎擠在一起。加上 -P(–pretty) 就好了。這樣:

jade -P xxx.jade

比如我們有這么一個(gè)使用了AngularJS的模板文件scope_template.jade,內(nèi)容如下:

doctype html
html(ng-app="myApp")
 head
 title= title
 link(rel='stylesheet', href='/stylesheets/style.css')
 body
 div(ng-controller="SimpleTemplate")
 | ValueA: 
 input(type="number" ng-model="valueA")
 br
 | ValueB: 
 input(type="number" ng-model="valueB")
 br
 br
 | Expression Value: {{valueA + valueB}}
 br
 br
 input(type="button" ng-click="addValues(valueA, valueB)" value="Click to Add Values {{valueA}} & {{valueB}}")
 br
 | Clicked Value: {{valueC}}
 br

 script(src="/javascripts/angular-1.4.3.min.js")
 script(src="/javascripts/scope_template.js")

運(yùn)行“jade -P scope_template.jade”命令會(huì)生成scope_template.html文件,內(nèi)容如下:

<!DOCTYPE html>
<html ng-app="myApp">
 <head>
 <title></title>
 <link rel="stylesheet" href="/stylesheets/style.css" rel="external nofollow" >
 </head>
 <body>
 <div ng-controller="SimpleTemplate">ValueA: 
 <input type="number" ng-model="valueA"><br>ValueB: 
 <input type="number" ng-model="valueB"><br><br>Expression Value: {{valueA + valueB}}<br><br>
 <input type="button" ng-click="addValues(valueA, valueB)" value="Click to Add Values {{valueA}} &amp; {{valueB}}"><br>Clicked Value: {{valueC}}<br>
 </div>
 <script src="/javascripts/angular-1.4.3.min.js"></script>
 <script src="/javascripts/scope_template.js"></script>
 </body>
</html>

需要提一下,我們既可以用jade編寫完整的HTML文檔,也可以編寫符合HTML語(yǔ)法的局部模板。比如下面的jade文件:

div(class="admin-user")
 p 添加用戶
 table
 tr
 td
 label 用戶名:
 td
 input(type="text" name="add_username")
 tr
 td
 label 密碼:
 td
 input(type="text" name="add_password") 
 tr
 td(colspan='2' align="right")
 input(type="submit" value="增加")

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • node.js基于socket.io快速實(shí)現(xiàn)一個(gè)實(shí)時(shí)通訊應(yīng)用

    node.js基于socket.io快速實(shí)現(xiàn)一個(gè)實(shí)時(shí)通訊應(yīng)用

    這篇文章主要介紹了node.js基于socket.io快速實(shí)現(xiàn)一個(gè)實(shí)時(shí)通訊應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 微信小程序在線客服自動(dòng)回復(fù)功能(基于node)

    微信小程序在線客服自動(dòng)回復(fù)功能(基于node)

    這篇文章主要介紹了微信小程序在線客服自動(dòng)回復(fù)功能(基于node),由于小程序嵌套webview時(shí)需要校驗(yàn)域名,因此跳轉(zhuǎn)到第三方應(yīng)用市場(chǎng)和Appstroe無(wú)法實(shí)現(xiàn)導(dǎo)流。那怎么辦呢,需要的朋友可以參考下
    2019-07-07
  • node中socket.io的事件使用詳解

    node中socket.io的事件使用詳解

    這篇文章主要介紹了node中socket.io的事件使用詳解,需要的朋友可以參考下
    2014-12-12
  • Node.js安裝、環(huán)境變量配置、報(bào)錯(cuò)解決方法

    Node.js安裝、環(huán)境變量配置、報(bào)錯(cuò)解決方法

    Node.js 是一個(gè)基于 Chrome JavaScript 運(yùn)行時(shí)建立的一個(gè)平臺(tái),這篇文章主要介紹了Node.js安裝、環(huán)境變量配置、報(bào)錯(cuò)解決方法,需要的朋友可以參考下
    2022-06-06
  • 深入理解Nodejs Global 模塊

    深入理解Nodejs Global 模塊

    本篇文章主要介紹了深入理解Nodejs Global 模塊,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06
  • 通過NodeJS輕松使用GRPC和協(xié)議緩沖區(qū)的方法

    通過NodeJS輕松使用GRPC和協(xié)議緩沖區(qū)的方法

    本文介紹了GRPC和協(xié)議緩沖區(qū)的基本概念,并展示了如何在NodeJS應(yīng)用程序中使用它們,GRPC是一個(gè)高性能RPC框架,協(xié)議緩沖區(qū)則用于定義服務(wù)和序列化消息,本文給大家介紹如何在NodeJS應(yīng)用程序中使用GRPC和協(xié)議緩沖區(qū),感興趣的朋友一起看看吧
    2024-10-10
  • 使用Node.js創(chuàng)建本地HTTP服務(wù)器并實(shí)現(xiàn)異地遠(yuǎn)程訪問的方法

    使用Node.js創(chuàng)建本地HTTP服務(wù)器并實(shí)現(xiàn)異地遠(yuǎn)程訪問的方法

    Node.js 是能夠在服務(wù)器端運(yùn)行 JavaScript 的開放源代碼、跨平臺(tái)運(yùn)行環(huán)境,這篇文章主要介紹了如何使用Node.js快速創(chuàng)建本地HTTP服務(wù)器并實(shí)現(xiàn)異地遠(yuǎn)程訪問,需要的朋友可以參考下
    2024-01-01
  • node快速搭建后臺(tái)的實(shí)現(xiàn)步驟

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

    本文主要介紹了node快速搭建后臺(tái),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Egg框架的功能、原理,以及基本使用方法概述

    Egg框架的功能、原理,以及基本使用方法概述

    這篇文章主要介紹了Egg框架的功能、原理,以及基本使用方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Egg框架的基本功能、原理、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2023-04-04
  • Node.js命令行/批處理中如何更改Linux用戶密碼淺析

    Node.js命令行/批處理中如何更改Linux用戶密碼淺析

    這篇文章主要給大家介紹了關(guān)于Node.js命令行/批處理中如何更改Linux用戶密碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07

最新評(píng)論