首頁 web前端 js教程 Nodejs的express使用教學(附程式碼)

Nodejs的express使用教學(附程式碼)

May 16, 2016 pm 03:30 PM
express nodejs

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(error, request, response , next){}

.三個的時候---第一個客戶請求request,第二個為伺服器回應respond,第三個為next中間件. 如function(request, response, next){} .兩個的時候---第一個客戶請求request,第二個為伺服器回應respondfunction. 如function(request, response){}

4.使用中間件use

app.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作為模版

9.response物件方法
{
  "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網頁

10.requst物件方法
//app.js
app.get('/', function(req, res) {
  res.render('index',{title:"最近文章"});
});
//index.js
this is !
登入後複製
.取得客戶ip位址:request.ip.取得上傳的檔案:request.files11.啟動腳本package.jsonpackage.json用於指定app信息,nodejs版本號和其他組件的依賴關係12.app入口app.jsapp.js主要包含http的創建,基本路由,監聽埠號 13.動態網頁範本viewsviews資料夾,用來存放所有的放網頁範本.

14.指定靜態網頁目錄

//app.js
app.use(express.static('public'));/ /指定靜態網頁目錄,當瀏覽器發出非HTML檔案請求時,伺服器端就到public目錄尋找這個檔案

如:, 伺服器端就到public/bootstrap/css/目錄尋找bootstrap.css文件

好了,本教學先給大家介紹到這裡,後續還會持續給大家更新,謝謝大家一直以來對PHP中文網的支持。

【相關教學推薦】

1. JavaScript影片教學
2. JavaScript線上手冊
3. bootstrap教學

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

nodejs和tomcat區別 nodejs和tomcat區別 Apr 21, 2024 am 04:16 AM

Node.js和Tomcat的主要差異在於:執行階段:Node.js基於JavaScript執行時,而Tomcat是Java Servlet容器。 I/O模型:Node.js採用非同步非阻塞模型,而Tomcat則是同步阻塞的。並發處理:Node.js透過事件循環處理並發,而Tomcat使用線程池。應用場景:Node.js適用於即時、資料密集和高並發應用程序,Tomcat適用於傳統Java Web應用程式。

nodejs和vuejs區別 nodejs和vuejs區別 Apr 21, 2024 am 04:17 AM

Node.js 是一種伺服器端 JavaScript 執行時,而 Vue.js 是一個客戶端 JavaScript 框架,用於建立互動式使用者介面。 Node.js 用於伺服器端開發,如後端服務 API 開發和資料處理,而 Vue.js 用於用戶端開發,如單一頁面應用程式和響應式使用者介面。

nodejs是後端框架嗎 nodejs是後端框架嗎 Apr 21, 2024 am 05:09 AM

Node.js 可作為後端框架使用,因為它提供高效能、可擴展性、跨平台支援、豐富的生態系統和易於開發等功能。

nodejs怎麼連接mysql資料庫 nodejs怎麼連接mysql資料庫 Apr 21, 2024 am 06:13 AM

要連接 MySQL 資料庫,需要遵循以下步驟:安裝 mysql2 驅動程式。使用 mysql2.createConnection() 建立連接對象,其中包含主機位址、連接埠、使用者名稱、密碼和資料庫名稱。使用 connection.query() 執行查詢。最後使用 connection.end() 結束連線。

nodejs中的全域變數有哪些 nodejs中的全域變數有哪些 Apr 21, 2024 am 04:54 AM

Node.js 中存在以下全域變數:全域物件:global核心模組:process、console、require執行階段環境變數:__dirname、__filename、__line、__column常數:undefined、null、NaN、Infinity、-Infinity

nodejs安裝目錄裡的npm與npm.cmd檔有什麼差別 nodejs安裝目錄裡的npm與npm.cmd檔有什麼差別 Apr 21, 2024 am 05:18 AM

Node.js 安裝目錄中有兩個與 npm 相關的文件:npm 和 npm.cmd,區別如下:擴展名不同:npm 是可執行文件,npm.cmd 是命令視窗快捷方式。 Windows 使用者:npm.cmd 可以在命令提示字元中使用,npm 只能從命令列執行。相容性:npm.cmd 特定於 Windows 系統,npm 跨平台可用。使用建議:Windows 使用者使用 npm.cmd,其他作業系統使用 npm。

nodejs和java的差別大嗎 nodejs和java的差別大嗎 Apr 21, 2024 am 06:12 AM

Node.js 和 Java 的主要差異在於設計和特性:事件驅動與執行緒驅動:Node.js 基於事件驅動,Java 基於執行緒驅動。單執行緒與多執行緒:Node.js 使用單執行緒事件循環,Java 使用多執行緒架構。執行時間環境:Node.js 在 V8 JavaScript 引擎上運行,而 Java 在 JVM 上運行。語法:Node.js 使用 JavaScript 語法,而 Java 使用 Java 語法。用途:Node.js 適用於 I/O 密集型任務,而 Java 適用於大型企業應用程式。

nodejs是後端開發語言嗎 nodejs是後端開發語言嗎 Apr 21, 2024 am 05:09 AM

是的,Node.js 是一種後端開發語言。它用於後端開發,包括處理伺服器端業務邏輯、管理資料庫連接和提供 API。

See all articles