Node.js 蠶食計劃(五)—— Koa 基礎項目搭建

来源:https://www.cnblogs.com/wisewrong/archive/2018/01/07/8202707.html
-Advertisement-
Play Games

Koa 是由 Express 原班人馬打造的超輕量服務端框架 與 Express 相比,除了自由度更高,可以自行引入中間件之外,更重要的是使用了 ES6 + async,從而避免了回調地獄 不過也是因為代碼升級,所以 Koa2 需要 v7.60 以上的 node.js 環境 一、創建項目 手動創建一 ...


Koa 是由 Express 原班人馬打造的超輕量服務端框架

與 Express 相比,除了自由度更高,可以自行引入中間件之外,更重要的是使用了 ES6 + async,從而避免了回調地獄

不過也是因為代碼升級,所以 Koa2 需要 v7.60 以上的 node.js 環境

 

一、創建項目

手動創建一個項目目錄,然後快速生成一個 package.json 文件

npm init -y

安裝 koa    //當前版本 2.4.1

npm install koa -S

然後創建一個 app.js

// app.js

const Koa = require('koa');
const app = new Koa();

app.use(async ctx => {
  ctx.body = 'Wise Wrong';
});

app.listen(3000);

最後在 package.json 中添加啟動指令

一個最基礎的 koa 應用就這樣完成了

可以執行 npm start 併在瀏覽器訪問 http://localhost:3000/ 查看效果

 

如果覺得手動創建項目太過繁瑣,可以使用腳手架 koa-generato 來生成項目

npm install koa-generator -g
koa2 project_name

然後在項目下 npm install 安裝依賴,npm start 啟動項目

如果是剛接觸 koa,建議先看完這篇博客,再使用腳手架工具,這樣能更好的理解各個依賴包的作用

 

 

二、配置路由

上面 app.js 中有一個 ctx,這是一個 Koa 提供的 Context 對象,封裝了 request 和 response

每一次 HTTP Request 都會創建一個 Context 對象

我們可以通過 Context.request.path 來獲取用戶請求的路徑,然後通過 Context.response.body 給用戶發送內容

Koa 預設的返回類型是 text/plain,如果要返回一個 html 文件(或者一個模塊文件),就需要修改 Context.response.type

另外,Context.response 可以簡寫,比如 Context.response.type 簡寫為 Context.type,Context.response.body 簡寫為 Context.type

 

在項目下創建一個存放 html 文件的目錄 views,併在該目錄下創建一個 index.html,然後修改 app.js

// app.js
// 原生路由
const Koa = require('koa'); const fs = require('fs'); const app = new Koa(); app.use(async (ctx, next) => { if (ctx.request.path === '/index') { ctx.type = 'text/html'; ctx.body = fs.createReadStream('./views/index.html'); } else { await next(); } }); app.listen(3000);

然後在瀏覽器中訪問 http://localhost:3000/index 就能看到 index.html 頁面,而訪問別的地址則是 not found

這樣處理 url 顯得特別笨拙,所以我們需要引入路由中間件 koa-router

npm install koa-router -S

需要註意的是,在導入 koa-router 的時候,需要在末尾加一個括弧:

const router = require('koa-router')();

相當於:

const koaRouter = require('koa-router');
const router = koaRouter();

 

創建一個 routes 目錄,用來存放路由文件,併在目錄下創建 index.js

// routes/index.js

const fs = require('fs');
const router = require('koa-router')()

router.get('/index', async (ctx, next) => {
  ctx.type = 'text/html';
  ctx.body = fs.createReadStream('./views/index.html');
});

module.exports = router

這裡還可以使用 prefix 方法,為文件中的所有介面添加一個 baseUrl

// router.prefix('/about')

 

修改 app.js

// app.js

const Koa = require('koa');
const app = new Koa();

const index = require('./routes/index')
app.use(index.routes(), index.allowedMethods())

app.listen(3000);

上面的 allowedMethods 用於校驗請求的方法,如果用 post 請求訪問 get 介面,就會直接返回失敗

 

另外,還可以在 url 中添加變數,然後通過 Context.params.name 訪問

router.get('/about/:name', async (ctx, next) => {
  ctx.body = `I am ${ctx.params.name}!`;
});

 

 

三、靜態資源

在上面的 index.html 中,如果需要引入 css 等靜態資源,就需要用到 koa-static

npm install koa-static -S

創建一個目錄 public 用來存放靜態資源

 然後在 app.js 中添加以下代碼

const static = require('koa-static');
// 將 public 目錄設置為靜態資源目錄
const main = static(__dirname + '/public');
app.use(main);

事實上,這三行代碼還可以優化

app.use(require('koa-static')(__dirname + '/public'));

然後就能在 index.html 中引入對應的文件了

 

 

四、模板引擎

上面的路由是使用 fs 模塊直接讀取 html 文件

開發的時候更推薦使用 koa-views 中間件來渲染頁面

npm install koa-views -S

在 app.js 中將 views 目錄設定為模版目錄

const views = require('koa-views')
app.use(views(__dirname + '/views'));

然後在路由文件中,就能使用 render 方法了

// routes/index.js

const router = require('koa-router')()

router.get('/index', async (ctx, next) => {
  await ctx.render('index');
});

module.exports = router

以上是直接渲染 html 文件的方法,如果要引入模板引擎,可以添加 extension 欄位來設定模版類型

app.use(views(__dirname + '/views', {
  extension: 'pug'    // 以 pug 模版為例
}))

 

 

五、結語

如果將 Express 看作 webstorm,那麼 Koa 就是 sublime

當 Express 流行的時候,其冗雜的依賴項被很多開發者所詬病

所以 Express 團隊將  Express 拆卸得只剩下最基本的骨架,讓開發者自行組裝,這就是 Koa

正如文中所說,從零開始太過繁瑣,可以使用腳手架 koa-generato 來快速開發

不過我更推薦,在熟悉了 Koa 之後,搭一個適合自己項目的腳手架

不然為何不直接用 Express 呢

我想這也是 Koa 的官方文檔中沒有提到 generato 工具的原因吧

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 在搭建大數據Hadoop相關的環境時候,遇到很多了很多錯誤。我是個喜歡做筆記的人,這些錯誤基本都記載,並且將解決辦法也寫上了。因此寫成博客,希望能夠幫助那些搭建大數據環境的人解決問題。 說明 : 遇到的問題以及相應的解決辦法是對於個人當時的環境,具體因人而異。如果碰到同樣的問題,本博客的方法無 ...
  • 話說昨晚,寫了一篇:講述Sagit.Framework解決:雙向引用導致的IOS記憶體泄漏(上)文章寫到最後時,多了很多莫名奇妙的問題!!!為瞭解決了這些莫名奇妙的問題,我又戰鬥了24小時〜〜〜然後終於解決了問題,原來是IOS的隱藏性Bug,只想恨恨的說一聲fuck~~~ ...
  • createClass本質上是一個工廠函數,extends的方式更加接近最新的ES6規範的class寫法。兩種方式在語法上的差別主要體現在方法的定義和靜態屬性的聲明上。createClass方式的方法定義使用逗號,隔開,因為creatClass本質上是一個函數,傳遞給它的是一個Object;而cla ...
  • 一、相容情況 說到ECMAScript6,順便提一下ECMAScript5,先看一下ES5的相容情況。ES5瀏覽器支持情況: Opera 11.60;Internet Explorer 9*;Firefox 4;Safari 5.1**;Chrome 13* IE9不支持嚴格模式 — IE10 添加 ...
  • 【獲得成就-十五篇博文打卡】 很開心不知不覺開通博客已經半個月了,雖然中間有兩天斷了,但是好歹沒放棄,一直在堅持,其實最難的事情還是堅持寫博客啊…… 今天狀態其實比昨天好些了,起碼晚上有足夠的時間寫代碼了,昨天那個sort的次數問題,今天也百度了很久,問了一些人,但是都還是沒弄懂,想了想就算了吧,要 ...
  • 寫在前面 其實網路上已經有許多關於如何美化博客園個人站點的文章,而我卻忍不住總是想寫點什麼。主要是因為我之前在如何選擇和美化博客園個人站點這個問題上走了許多彎路,一開始徘徊於如何選擇一個好看的模板,後來又在調整模板樣式上總覺得不盡如意。直到有一天,我看見了一片博客園的文章,頓時覺得其版權大氣而簡潔, ...
  • Javascipt數組 在Javascript中數組的做用是:使用單獨的變數名來儲存一系列的值。 數組只有一個屬性,就是length,length表示的數組所占記憶體空間的數目。 1.創建數組 創建數組方法1: 創建數組方法2: 2.數組合併 數組合併方法1: 數組合併方法2: 3.把數組合成字元串 ...
  • Javascript流程式控制制 1.條件語句 (1)if(exp)執行一句代碼 (2)if(exp){執行代碼段;} (3)if(exp){exp為true執行代碼段}else{exp為false執行的代碼段} (4)if...else if... (5)if嵌套 2.迴圈語句 (1)for 迴圈 ( ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...