從零開(kāi)始學(xué)習(xí)Node.js系列教程之基于connect和express框架的多頁(yè)面實(shí)現(xiàn)數(shù)學(xué)運(yùn)算示例
本文實(shí)例講述了Node.js基于connect和express框架的多頁(yè)面實(shí)現(xiàn)數(shù)學(xué)運(yùn)算。分享給大家供大家參考,具體如下:
1、使用connect框架
.use方法用于綁定中間件到connect服務(wù)器,它會(huì)配置一系列在接到請(qǐng)求時(shí)調(diào)用的中間件模塊,此例中我們要配置的中間件有favicon logger static router
app.get/post/put 寫法:app.requestName('path', function(req, res, next){});
app-connect.js
var connect = require('connect'); //npm install connect
connect.createServer()
.use(connect.favicon())
.use(conect.logger())
.use('/filez', connect.static(__dirname + '/filez'))
.use(connect.router(function(app){
app.get('/', require('./home-node').get);
//一個(gè)URL字符串和兩個(gè)函數(shù)類型的參數(shù)
//路由器配置函數(shù)可以包含不限數(shù)量的函數(shù),你可以為自己的應(yīng)用構(gòu)造一個(gè)處理函數(shù)的隊(duì)列
app.get('/square', htutil.loadParams, require('./square-node').get);
app.get('/factorial', htutil.loadParams, require('./factorial-node').get);
app.get('/fibonacci', htutil.loadParams, require('./fibo2-node').get);
app.get('/mult', htutil.loadParams, require('./mult-node').get);
})).listen(3000);
console.log('listening to http://localhost:3000');
2、使用express框架
Express框架是一個(gè)基于connect(一個(gè)中間件框架)的web應(yīng)用框架
Express專注于構(gòu)建一個(gè)應(yīng)用,包括提供一個(gè)模板系統(tǒng);connect專注于做web服務(wù)的基礎(chǔ)設(shè)施
安裝Express和EJS(模塊處理系統(tǒng)) npm install express ejs
app-express.js
var htutil = require('./htutil');
var math = require('./math');
var express = require('express');
//var app = express.createServer(express.logger()); //express 2.X
var app = express(); //express 3.X
//可選,因?yàn)镋xpress下默認(rèn)為CWD/views
app.set('views', __dirname + '/views');
app.engine('.html', require('ejs').__express);
app.set('view engine', 'ejs');
app.configure(function(){
app.use(app.router);
app.use(express.static(__dirname + '/filez'));
//默認(rèn)的錯(cuò)誤處理函數(shù),顯示棧軌跡
//如果要顯示用戶友好的錯(cuò)誤,app.err(function(err, req, res, next){
// res.send(error page); //or res.render('template');
// });
app.use(express.errorHandler({
dumpExceptions: true, showStack: true
}));
/*
改成下面的話,瀏覽器會(huì)顯示一個(gè)簡(jiǎn)單的消息-Internal Server Error內(nèi)部服務(wù)器錯(cuò)誤
app.use(express.errorHandler({
dumpExceptions: true
}));
*/
});
//以上配置了必需的中間件,因?yàn)檫@里展示的配置項(xiàng)對(duì)應(yīng)的是模板系統(tǒng)的配置,所有.html文件會(huì)由EJS引擎處理
//以下是路由器配置
app.get('/', function(req, res){
res.render('home.html', {title: "Math Wizard"});
});
app.get('/mult', htutil.loadParams, function(req, res){
if (req.a && req.b) req.result = req.a * req.b;
res.render('mult.html', {title: "Math Wizard", req: req});
});
app.get('/square', htutil.loadParams, function(req, res){
if (req.a) req.result = req.a * req.a;
res.render('square.html', {title: "Math Wizard", req: req});
});
app.get('/fibonacci', htutil.loadParams, function(req, res){
if (req.a){
math.fibonacciAsync(Math.floor(req.a), function(val){
req.result = val;
res.render('fibo.html', {title: "Math Wizard", req: req});
});
}else {
res.render('fibo.html', {title: "Math Wizard", req: req});
}
});
app.get('/factorial', htutil.loadParams, function(req, res){
if (req.a) req.result = math.factorial(req.a);
res.render('factorial.html', {title: "Math Wizard", req: req});
});
app.get('/404', function(req, res){
res.send('NOT FOUND' + req.url);
});
//res.render函數(shù)通過(guò)一個(gè)模板文件渲染數(shù)據(jù),EJS只是Express里眾多模板引擎中的一個(gè)
//配置目的是讓EJS能夠?yàn)関iews目錄下的所有.html文件服務(wù)
/*Express里還有其他一些模板引擎
res.render('index.haml', {..data..}); 使用Haml
res.render('index.jade', {..data..}); 使用Jade
res.render('index.ejs', {..data..}); 使用EJS
res.render('index.coffee', {..data..}); 使用CoffeeKup
res.render('index.jqtpl', {..data..}); 使用jQueryTemplates
也可以通過(guò) app.set('view engine', 'haml');
app.set('view engine', 'jade'); 方法來(lái)改變默認(rèn)的渲染引擎
layout.html
默認(rèn)情況下,模板中用于渲染的內(nèi)容會(huì)被命名為body,然后傳遞到layout模板中,當(dāng)app-express.js調(diào)用
res.render('fibo.html'...)時(shí),它會(huì)先用fibo.html渲染對(duì)應(yīng)的頁(yè)面片段,然后再使用layout模板渲染整個(gè)頁(yè)面
有兩種方法覆蓋這一默認(rèn)的行為
1、在Express里創(chuàng)建一個(gè)全局的配置,通過(guò)這個(gè)全局配置來(lái)控制layout模板的啟用與禁用
app.set('view options', {layout: false(or true)});
2、覆蓋layout模板對(duì)應(yīng)的渲染方式或者使用不同的layout模板
res.render('myview.ejs', {layout: false(or true)});
或者res.render('page', {layout: 'mylayout.jade'});
<% code %> Javascript代碼
<%= code %> 顯示替換過(guò)HTML特殊字符的內(nèi)容
<%- code %> 顯示原始HTML內(nèi)容
*/
app.listen(3000);
console.log('listening to http://localhost:3000');
html頁(yè)面放在views目錄下
layout.html
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<h1><%=title%></h1>
<table>
<tr>
<td>
<div class="navbar">
<p><a href="/" rel="external nofollow" >home</a></p>
<p><a href="/mult" rel="external nofollow" >Multiplication</a></p>
<p><a href="/square" rel="external nofollow" >Square</a></p>
<p><a href="/factorial" rel="external nofollow" >Factorial</a></p>
<p><a href="/fibonacci" rel="external nofollow" >Fibonacci</a></p>
</div>
</td>
<td></td>
</tr>
</table>
</body>
</html>
home.html
<% include layout.html %> <p>Math Wizard</p>
mult.html
<% include layout.html %>
<% if (req.a && req.b){ %>
<p class="result">
<%=req.a%> * <%=req.b%> = <%=req.result%>
</p>
<% } %>
<p>Enter numbers to multiply</p>
<form name="mult" action="/mult" method="get">
A: <input type="text" name="a" /><br/>
B: <input type="text" name="b" />
<input type="submit" name="Submit" />
</form>
還有其他一些頁(yè)面就不一一列出來(lái)了,都大同小異
希望本文所述對(duì)大家nodejs程序設(shè)計(jì)有所幫助。
- 從零開(kāi)始學(xué)習(xí)Node.js系列教程之設(shè)置HTTP頭的方法示例
- 從零開(kāi)始學(xué)習(xí)Node.js系列教程之SQLite3和MongoDB用法分析
- 從零開(kāi)始學(xué)習(xí)Node.js系列教程六:EventEmitter發(fā)送和接收事件的方法示例
- 從零開(kāi)始學(xué)習(xí)Node.js系列教程五:服務(wù)器監(jiān)聽(tīng)方法示例
- 從零開(kāi)始學(xué)習(xí)Node.js系列教程四:多頁(yè)面實(shí)現(xiàn)數(shù)學(xué)運(yùn)算的client端和server端示例
- 從零開(kāi)始學(xué)習(xí)Node.js系列教程四:多頁(yè)面實(shí)現(xiàn)的數(shù)學(xué)運(yùn)算示例
- 從零開(kāi)始學(xué)習(xí)Node.js
相關(guān)文章
總結(jié)幾道關(guān)于Node.js的面試問(wèn)題
這篇文章主要總結(jié)了幾道關(guān)于Node.js的面試問(wèn)題,通過(guò)這些問(wèn)題就來(lái)判斷一個(gè)人的Node.js水平是不太嚴(yán)謹(jǐn)?shù)?,但是它能讓你?duì)面試者在Node.js上的經(jīng)驗(yàn)如何有個(gè)大概的了解。有需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-01-01
Node 搭建一個(gè)靜態(tài)資源服務(wù)器的實(shí)現(xiàn)
這篇文章主要介紹了Node 搭建一個(gè)靜態(tài)資源服務(wù)器的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
解決Node.js包管理器安裝報(bào)錯(cuò)npm?ERR!?code?1的問(wèn)題
在開(kāi)發(fā)過(guò)程中,我們經(jīng)常需要使用各種Node.js包來(lái)擴(kuò)展我們的應(yīng)用程序功能,這些包通常通過(guò)npm(Node.js包管理器)進(jìn)行安裝和管理,有時(shí)候我們可能會(huì)遇到一些關(guān)于npm的錯(cuò)誤,本文將詳細(xì)介紹如何解決這個(gè)問(wèn)題,并提供一個(gè)詳細(xì)的實(shí)例,需要的朋友可以參考下2024-03-03
詳解如何利用Nodejs構(gòu)建多進(jìn)程應(yīng)用
這篇文章主要為大家介紹了如何利用Nodejs構(gòu)建多進(jìn)程應(yīng)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
淺談node如何優(yōu)雅地獲取mac系統(tǒng)版本
這篇文章主要和大家聊聊node如何優(yōu)雅地獲取mac系統(tǒng)版本,文中有詳細(xì)的代碼示例和流程步驟,對(duì)我們學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-06-06
package.json與package-lock.json創(chuàng)建及使用詳解
這篇文章主要為大家介紹了package.json與package-lock.json創(chuàng)建及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Node.js實(shí)現(xiàn)批量替換文件內(nèi)容示例
這篇文章主要為大家介紹了Node.js實(shí)現(xiàn)批量替換文件內(nèi)容示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
Docker平臺(tái)下NodeJs?Puppeteer實(shí)現(xiàn)html轉(zhuǎn)pdf過(guò)程示例
這篇文章主要為大家介紹了Docker平臺(tái)下NodeJs?Puppeteer實(shí)現(xiàn)html轉(zhuǎn)pdf過(guò)程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12

