日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
5分鐘教你用Node.Js手寫一個(gè)Mock數(shù)據(jù)服務(wù)

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

創(chuàng)新互聯(lián)建站專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于做網(wǎng)站、成都網(wǎng)站制作、竹溪網(wǎng)絡(luò)推廣、小程序定制開發(fā)、竹溪網(wǎng)絡(luò)營(yíng)銷、竹溪企業(yè)策劃、竹溪品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)建站為所有大學(xué)生創(chuàng)業(yè)者提供竹溪建站搭建服務(wù),24小時(shí)服務(wù)熱線:13518219792,官方網(wǎng)址:www.cdcxhl.com

我們將學(xué)到

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

mock服務(wù)器基本設(shè)計(jì)思路

通過目錄路徑和服務(wù)端api的映射關(guān)系來實(shí)現(xiàn)我們的api訪問,比如我們?cè)L問接口/api/article/122,我們只需要在mock服務(wù)期目錄的api的article目錄下,創(chuàng)建122.json文件即可,json文件的數(shù)據(jù)可以自定義,方便前端調(diào)試。

具體實(shí)現(xiàn)

1.搭建一個(gè)node服務(wù)

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

2.注冊(cè)路由 我們使用koa-router來實(shí)現(xiàn)后臺(tái)服務(wù)的路由功能,并通過koa提供的上下文ctx將讀取到的數(shù)據(jù)返回給前端:

 
 
 
 
  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) 

這樣我們就能實(shí)現(xiàn)一個(gè)勉強(qiáng)能用的基本的后臺(tái)api服務(wù)器了,當(dāng)我們請(qǐng)求/api/name時(shí),會(huì)返回相應(yīng)的數(shù)據(jù)給前臺(tái),這一步是我們實(shí)現(xiàn)mock服務(wù)的關(guān)鍵一步,接下來我們具體來實(shí)現(xiàn)目錄的遍歷和api的自動(dòng)注冊(cè)。

3.自動(dòng)注冊(cè)api接口并返回?cái)?shù)據(jù) 我們將在這個(gè)階段實(shí)現(xiàn)api服務(wù)的自動(dòng)注冊(cè),這里我們使用glob這個(gè)第三方模塊來遍歷目錄,并通過node的fs模塊讀取api文件的數(shù)據(jù)并返回給前臺(tái)。glob的使用很簡(jiǎn)單,感興趣的朋友可以自行學(xué)習(xí),這里就不做過多介紹了。具體實(shí)現(xiàn)如下:

 
 
 
 
  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. // 注冊(cè)路由 
  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' // 自定義響應(yīng)體 
  22.             } 
  23.         }catch(err) { 
  24.             ctx.throw('服務(wù)器錯(cuò)誤', 500); 
  25.         } 
  26.       }); 
  27. }); 
  28.   
  29. app 
  30.   .use(router.routes()) 
  31.   .use(router.allowedMethods()); 
  32.  
  33. app.listen(3000); 

添加控制臺(tái)日志 我們使用koa-logger實(shí)現(xiàn)在終端打印node日志,方便調(diào)試,雖然這不是該文章的重點(diǎn),但是對(duì)于想做node開發(fā)的前端從業(yè)者,還是很有必要了解的。

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

這樣,我們每個(gè)請(qǐng)求都會(huì)在終端打印出來。

路由映射文件的生成 該功能也不是本文的重點(diǎn),但是會(huì)極大的方便前端開發(fā)者調(diào)試請(qǐng)求,因?yàn)槿绻鸻pi路徑很長(zhǎng),我們需要一個(gè)個(gè)查找,但是有了這個(gè)map文件,我們只需要拷貝自動(dòng)生成的路徑即可。具體實(shí)現(xiàn)如下:

 
 
 
 
  1. //... 
  2. const routerMap = {};  // 存放路由映射 
  3.  
  4. // 注冊(cè)路由 
  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. }); 

基本目錄結(jié)構(gòu)

github地址:

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

歡迎大家相互學(xué)習(xí)交流,一起探索前端的邊界。


名稱欄目:5分鐘教你用Node.Js手寫一個(gè)Mock數(shù)據(jù)服務(wù)
URL網(wǎng)址:http://www.5511xx.com/article/djodsjh.html