成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

5分鐘教你用Node.Js手寫一個Mock數據服務

開發 前端
對于前端開發者而言,javascript正扮演著越來越重要的地位,它不僅能為瀏覽器端賦能,在web服務器方面也有很大的價值(我們可以用nodeJS來寫服務端代碼,啟動web服務器),因此本文所要描述的,便是javascript在服務端的應用。

[[423354]]

對于前端開發者而言,javascript正扮演著越來越重要的地位,它不僅能為瀏覽器端賦能,在web服務器方面也有很大的價值(我們可以用nodeJS來寫服務端代碼,啟動web服務器),因此本文所要描述的,便是javascript在服務端的應用。我將介紹如何使用nodeJS來搭建一個mock服務器,方便前端自定義mock數據請求,提高前端開發著的主觀能動性和對項目健壯性的探索。

我們將學到

  • koa基本使用
  • koa-router的基本用法
  • koa-logger的使用
  • glob支持文件遍歷查尋
  • node幾個核心api的使用
  • 使用nodemon做自動重啟

mock服務器基本設計思路

通過目錄路徑和服務端api的映射關系來實現我們的api訪問,比如我們訪問接口/api/article/122,我們只需要在mock服務期目錄的api的article目錄下,創建122.json文件即可,json文件的數據可以自定義,方便前端調試。

具體實現

1.搭建一個node服務

  1. const Koa = require('koa'); 
  2. const app = new Koa(); 
  3. app.listen(3000) 

2.注冊路由 我們使用koa-router來實現后臺服務的路由功能,并通過koa提供的上下文ctx將讀取到的數據返回給前端:

  1. const Koa = require('koa'); 
  2. const Router = require('koa-router'); 
  3.   
  4. const app = new Koa(); 
  5. const router = new Router({prefix: '/api'}); 
  6.  
  7. router.get('/name', (ctx, next) => { 
  8.     ctx.body = { 
  9.         name'xuxiaoxi' 
  10.     } 
  11.   }); 
  12.  
  13. app 
  14.   .use(router.routes()) 
  15.   .use(router.allowedMethods()); 
  16.    
  17. app.listen(3000) 

這樣我們就能實現一個勉強能用的基本的后臺api服務器了,當我們請求/api/name時,會返回相應的數據給前臺,這一步是我們實現mock服務的關鍵一步,接下來我們具體來實現目錄的遍歷和api的自動注冊。

3.自動注冊api接口并返回數據 我們將在這個階段實現api服務的自動注冊,這里我們使用glob這個第三方模塊來遍歷目錄,并通過node的fs模塊讀取api文件的數據并返回給前臺。glob的使用很簡單,感興趣的朋友可以自行學習,這里就不做過多介紹了。具體實現如下:

  1. const Koa = require('koa'); 
  2. const Router = require('koa-router'); 
  3. const glob = require("glob"); 
  4. const { resolve } = require('path'); 
  5. const fs = require('fs'); 
  6.   
  7. const app = new Koa(); 
  8. const router = new Router({prefix: '/api'}); 
  9.  
  10. // 注冊路由 
  11. glob.sync(resolve('./api'"**/*.json")).forEach((item, i) => { 
  12.     let apiJsonPath = item && item.split('/api')[1]; 
  13.     let apiPath = apiJsonPath.replace('.json'''); 
  14.      
  15.     router.get(apiPath, (ctx, next) => { 
  16.         try { 
  17.             let jsonStr = fs.readFileSync(item).toString(); 
  18.             ctx.body = { 
  19.                 data: JSON.parse(jsonStr), 
  20.                 state: 200, 
  21.                 type: 'success' // 自定義響應體 
  22.             } 
  23.         }catch(err) { 
  24.             ctx.throw('服務器錯誤', 500); 
  25.         } 
  26.       }); 
  27. }); 
  28.   
  29. app 
  30.   .use(router.routes()) 
  31.   .use(router.allowedMethods()); 
  32.  
  33. app.listen(3000); 

添加控制臺日志 我們使用koa-logger實現在終端打印node日志,方便調試,雖然這不是該文章的重點,但是對于想做node開發的前端從業者,還是很有必要了解的。

  1. const logger = require('koa-logger'
  2. app.use(logger()); 

這樣,我們每個請求都會在終端打印出來。

路由映射文件的生成 該功能也不是本文的重點,但是會極大的方便前端開發者調試請求,因為如果api路徑很長,我們需要一個個查找,但是有了這個map文件,我們只需要拷貝自動生成的路徑即可。具體實現如下:

  1. //... 
  2. const routerMap = {};  // 存放路由映射 
  3.  
  4. // 注冊路由 
  5. glob.sync(resolve('./api'"**/*.json")).forEach((item, i) => { 
  6.     // ... 
  7.      
  8.     // 記錄路由 
  9.     routerMap[apiJsonPath] = apiPath; 
  10. }); 
  11.  
  12. fs.writeFile('./routerMap.json', JSON.stringify(routerMap, null , 4), err => { 
  13.     if(!err) { 
  14.         console.log('路由地圖生成成功!'
  15.     } 
  16. }); 

基本目錄結構

github地址:

https://github.com/MrXujiang/openCoder/tree/master/mockServer

 

歡迎大家相互學習交流,一起探索前端的邊界。

 

責任編輯:武曉燕 來源: 趣談前端
相關推薦

2022-01-17 09:01:23

NodeJS數據服務器Mock

2022-06-28 12:35:21

DockerPython

2022-06-05 13:52:32

Node.jsDNS 的原理DNS 服務器

2022-01-06 18:20:20

Scarlet AndroidWebSocket

2020-03-17 13:24:04

微服務架構數據

2019-07-24 09:28:36

Node.jskoa架構

2019-01-16 18:34:37

Python 開發數據

2022-10-12 23:02:49

Calcite異構數據框架

2021-07-29 23:29:55

web服務器開發

2020-10-30 15:04:16

開發技能代碼

2011-06-17 10:29:04

Nodejavascript

2009-11-11 16:08:21

ADO.NET數據服務

2011-10-25 09:28:30

Node.js

2020-08-07 10:40:56

Node.jsexpress前端

2017-10-11 15:17:42

sklearn機器學習pandas

2022-03-11 09:10:10

hooksReact自定義

2012-03-02 13:10:08

筆記本常見問題

2020-10-29 16:00:03

Node.jsweb前端

2012-02-22 15:55:48

JavaPlay Framew

2023-05-27 21:13:34

FlaskURL裝飾器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产视频一区二区 | 亚洲免费在线播放 | 精品国产乱码久久久久久影片 | 日韩精品色网 | 一级全黄少妇性色生活免费看 | 天天草天天射 | 亚洲视频一区在线 | 成人免费在线观看 | a级大片免费观看 | 精品一区二区三区视频在线观看 | 国产色在线 | 免费国产一区二区 | 亚洲视频在线一区 | 黄片毛片在线观看 | 男人的天堂久久 | 国产污视频在线 | 国产在线视频一区二区董小宛性色 | 羞羞的视频免费看 | 国产欧美一区二区三区国产幕精品 | 中文区中文字幕免费看 | 蜜桃臀av一区二区三区 | 欧美不卡视频 | www久久av | 国产伦精品一区二区三区照片91 | 在线观看的av | 久久久精彩视频 | 欧美成人二区 | 黄 色 毛片免费 | 国产精久久久久久 | 亚洲第一在线视频 | 国产极品粉嫩美女呻吟在线看人 | 亚洲欧美高清 | 日韩欧美一区二区三区 | 国产欧美性成人精品午夜 | 亚洲成人av在线 | 国产在线a | 天天躁日日躁狠狠很躁 | 欧美在线一区二区三区 | 色婷综合网 | 欧美一区在线视频 | 国产传媒视频在线观看 |