亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

5分鐘教你用nodeJS手寫一個mock數據服務器的方法

2019-11-19 10:50:27
字體:
來源:轉載
供稿:網友

對于前端開發者而言,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服務

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

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

const Koa = require('koa');const Router = require('koa-router'); const app = new Koa();const router = new Router({prefix: '/api'}); router.get('/name', (ctx, next) => {  ctx.body = {    name: 'xuxiaoxi'  } }); app .use(router.routes()) .use(router.allowedMethods()); app.listen(3000)

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

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

const Koa = require('koa');const Router = require('koa-router');const glob = require("glob");const { resolve } = require('path');const fs = require('fs'); const app = new Koa();const router = new Router({prefix: '/api'}); // 注冊路由glob.sync(resolve('./api', "**/*.json")).forEach((item, i) => {  let apiJsonPath = item && item.split('/api')[1];  let apiPath = apiJsonPath.replace('.json', '');    router.get(apiPath, (ctx, next) => {    try {      let jsonStr = fs.readFileSync(item).toString();      ctx.body = {        data: JSON.parse(jsonStr),        state: 200,        type: 'success' // 自定義響應體      }    }catch(err) {      ctx.throw('服務器錯誤', 500);    }   });}); app .use(router.routes()) .use(router.allowedMethods()); app.listen(3000);

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

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

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

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

//...const routerMap = {}; // 存放路由映射 // 注冊路由glob.sync(resolve('./api', "**/*.json")).forEach((item, i) => {  // ...    // 記錄路由  routerMap[apiJsonPath] = apiPath;}); fs.writeFile('./routerMap.json', JSON.stringify(routerMap, null , 4), err => {  if(!err) {    console.log('路由地圖生成成功!')  }});

基本目錄結構

完整代碼

clone地址  github地址 

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩黄色高清视频| 亚洲色图50p| 成人免费黄色网| 免费99精品国产自在在线| 日韩国产中文字幕| 久久久久久欧美| 国产精品入口免费视| 成人免费视频网| 欧美最猛性xxxxx亚洲精品| 久久久噜噜噜久久久| 精品人伦一区二区三区蜜桃网站| 日本免费在线精品| 日韩精品中文字幕在线| 少妇激情综合网| 日韩精品在线免费观看| 日本精品免费一区二区三区| 日韩一区二区福利| 国产精品夜间视频香蕉| 欧美中文字幕在线播放| 国产精品96久久久久久又黄又硬| 国产xxx69麻豆国语对白| 欧美一级淫片aaaaaaa视频| 亚洲欧美自拍一区| 91在线高清免费观看| 性色av一区二区三区红粉影视| 成人xvideos免费视频| 亚洲精品国偷自产在线99热| 久久国产一区二区三区| 91在线免费观看网站| 欧美极品少妇与黑人| 国产精品久久久久久久7电影| 国产精品久久久久久久久男| 成人www视频在线观看| 亚洲男人天堂九九视频| 亚洲欧美日韩在线一区| 伊人久久大香线蕉av一区二区| 亚洲一区二区三区成人在线视频精品| 日韩欧美一区二区三区久久| 2019中文字幕在线| 亚洲欧洲在线观看| 亚洲欧美视频在线| 狠狠色香婷婷久久亚洲精品| 在线观看视频亚洲| 神马久久桃色视频| 7m精品福利视频导航| 国产主播在线一区| 91久久精品久久国产性色也91| 日韩在线观看免费全集电视剧网站| 98精品国产高清在线xxxx天堂| 伊人久久五月天| 国产成人精品在线视频| 国产精自产拍久久久久久蜜| 国产免费久久av| 亚洲xxxxx| 日韩在线不卡视频| 亚洲精品福利资源站| 另类色图亚洲色图| 欧美激情小视频| 97在线视频免费看| 国产视频精品一区二区三区| 欧美高跟鞋交xxxxxhd| 海角国产乱辈乱精品视频| 欧美激情第三页| 国产精品爽黄69天堂a| 中文字幕日韩在线观看| 日本欧美精品在线| 国产人妖伪娘一区91| 亚洲最大福利视频网| 久久久久亚洲精品| 51ⅴ精品国产91久久久久久| 中日韩美女免费视频网址在线观看| 久久久av亚洲男天堂| 国产精品视频yy9099| 成人免费xxxxx在线观看| 久久久久一本一区二区青青蜜月| 国产免费一区二区三区香蕉精| 国产日韩欧美在线观看| 中文字幕成人精品久久不卡| 宅男66日本亚洲欧美视频| 国产精品青草久久久久福利99| 日韩av快播网址| 91黑丝在线观看| 日韩电视剧免费观看网站| 欧美日韩激情视频| 日韩欧美亚洲范冰冰与中字| 91系列在线播放| 欧美黑人xxxⅹ高潮交| 日韩精品小视频| 久久天天躁狠狠躁老女人| 精品无人区乱码1区2区3区在线| 亚洲国产成人在线视频| 久久天天躁狠狠躁老女人| 在线播放国产一区中文字幕剧情欧美| 68精品国产免费久久久久久婷婷| 91国内揄拍国内精品对白| 成人精品一区二区三区电影免费| 欧美日韩国产丝袜美女| 狠狠色狠色综合曰曰| 国产成人精品一区二区三区| 不用播放器成人网| 国产精品第100页| 18性欧美xxxⅹ性满足| 2019国产精品自在线拍国产不卡| 亚洲国产中文字幕久久网| 免费av一区二区| 性欧美亚洲xxxx乳在线观看| 久久综合88中文色鬼| 国产精品午夜国产小视频| 亚洲精品suv精品一区二区| 91久久精品久久国产性色也91| 高潮白浆女日韩av免费看| 欧美老女人在线视频| 国产成人精品一区二区三区| 欧美激情久久久久| 欧美性一区二区三区| 亚洲天堂视频在线观看| 国产亚洲精品一区二555| 国产成人在线精品| 亚洲桃花岛网站| 成人午夜黄色影院| 亚洲成人网久久久| 精品久久久中文| 亚洲色图偷窥自拍| 亚洲人成网在线播放| 国产日韩在线精品av| 久久人人爽亚洲精品天堂| 91精品国产色综合| 色一情一乱一区二区| 日韩电影中文字幕在线| 中文字幕av一区二区三区谷原希美| 亚洲91av视频| 日韩大片在线观看视频| 亚洲最大成人免费视频| 久久国产色av| 91精品免费久久久久久久久| 国产精品香蕉在线观看| 国产在线拍揄自揄视频不卡99| 欧美激情精品久久久久久久变态| 性色av一区二区三区| 日韩精品在线看| 在线播放国产一区中文字幕剧情欧美| 欧美日韩国产丝袜另类| 欧美成人免费全部| 亚洲一区二区久久久久久| 亚洲第一精品福利| 欧美日韩国产第一页| 成人信息集中地欧美| 亚洲天天在线日亚洲洲精| 久久久久久久999精品视频| 精品香蕉一区二区三区| 伊人久久久久久久久久久| 国产成人精品久久二区二区91| 97香蕉久久超级碰碰高清版| 国内精品久久影院| 欧美在线视频网| y97精品国产97久久久久久| 国产精品视频久久久| 少妇久久久久久| 亚洲国产精品美女| 黑人巨大精品欧美一区二区三区| 久久久精品免费视频| 亚洲专区中文字幕| 欧美日韩精品在线| 国产成人精品一区二区三区|