Express 是一個簡潔、靈活的 node.js Web 應用開發框架, 它提供一系列強大的特性,幫助你創建各種 Web 和行動裝置應用。
1.express組織結構
app demo
|---node_modules------用於安裝本地模組。
|---public------------用來存放使用者可以下載到的文件,例如圖片、腳本、樣式表等。
|---routes------------用來存放路由文件。
|---views-------------用來存放網頁的範本。
|---app.js------------應用程式的啟動腳本。
|---package.json------專案的設定檔。
2..建立express伺服器
//app.js文件 var express = require('express'); var app = express(); //指定更目录显示的内容 app.get('/', function(req, res){ res.send('Hello World'); }); //指定监听端口 var server = app.listen(3000, function() { console.log('Listening on port %d', server.address().port); });
執行nodejs>
執行nodejs>
/>node app.js
3.中間件
中間件(middleware)就是處理HTTPiddleware. >當一個HTTP請求進入伺服器,伺服器實例會呼叫第一個中間件,完成後根據設置,決定是否再呼叫下一個中間件.
中間件的參數為:
.三個的時候---第一個客戶請求request,第二個為伺服器回應respond,第三個為next中間件. 如function(request, response, next){} .兩個的時候---第一個客戶請求request,第二個為伺服器回應respondfunction. 如function(request, response){}
4.使用中間件useapp.use(function(request, response) { response.writeHead(200, { "Content-Type": "text/plain" }); response.end("Hello world!\n"); });use是express呼叫中間件的方法,它傳回一個函數.
5.錯誤內容顯示
app.use(express.bodyParser());//使用body参数 app.use(express.methodOverride());//使用函数覆盖 app.use(app.router);//使用路由 app.use(function(err, req, res, next){ console.error(err.stack); res.send(500, 'Something broke!'); });//错误内容显示
6.路由
6.路由
app.get("*", function(request, response) { response.end("404!"); });//所有路径都返回404
app.get("/hello/:who", function(req, res) { res.end("Hello, " + req.params.who + "."); });//如"/hello/alice”网址,网址中的alice将被捕获,作为req.params.who属性的值
express路由的方式有很多種,這裡舉例常用的幾種:.app.use('/', middleware);//get/post時,對於路徑/的處理.app.get("/", middleware);//http中get時,路徑/的處理
.app.post("/", middleware);//http中post時,路徑/的處理.app.put("/", middleware);//http中put時,路徑/的處理
.app.delete("/", middleware);//http中delete時,對於路徑/的處理
7.路徑通配符*
.:捕獲路徑內容
8.設定環境變數set用於指定變數的值.app.set("view engine", "ejs");//使用ejs作為模版
{ "name": "demo", "description": "My First Express App", "version": "0.0.1", "dependencies": { "express": "3.x" } }
.重定向redirect response.redirect("/hello/anime");//重定向到/hello/anime
.傳送檔案sendFile
response.sendFile("/path/to/anime.mp4");.渲染網頁範本render,也就是將變換的內容載入到網頁. response.render("index", { message: "Hello World" });//將message變數傳入index模板,值為"Hello World"渲染成HTML網頁
//app.js app.get('/', function(req, res) { res.render('index',{title:"最近文章"}); }); //index.js this is !
14.指定靜態網頁目錄
//app.js
app.use(express.static('public'));/ /指定靜態網頁目錄,當瀏覽器發出非HTML檔案請求時,伺服器端就到public目錄尋找這個檔案
如:, 伺服器端就到public/bootstrap/css/目錄尋找bootstrap.css文件
好了,本教學先給大家介紹到這裡,後續還會持續給大家更新,謝謝大家一直以來對PHP中文網的支持。
【相關教學推薦】