成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

faked 一個(gè)用于 mock 后端 API 的輕量工具

wind3110991 / 3319人閱讀

摘要:一簡(jiǎn)介是一個(gè)在前端開(kāi)發(fā)中用于服務(wù)端接口的模塊,輕量簡(jiǎn)單,無(wú)需要在本地啟動(dòng)也無(wú)需其它更多的資源,僅在瀏覽器中完成請(qǐng)求拉截,配合完整的路由系統(tǒng)輕而易舉的后端。

一、簡(jiǎn)介

faked 是一個(gè)在前端開(kāi)發(fā)中用于 mock 服務(wù)端接口的模塊,輕量簡(jiǎn)單,無(wú)需要在本地啟動(dòng) Server 也無(wú)需其它更多的資源,僅在瀏覽器中完成「請(qǐng)求拉截」,配合完整的「路由系統(tǒng)」輕而易舉的 mock 后端 API。

GitHub Rep 地址:https://github.com/Houfeng/faked

二、安裝 faked

有兩種可選安裝方式,你可以通過(guò)傳統(tǒng)的 sciprt 方式引入 faked,如果你采用了 CommonJs 或 ES6 Modules 模塊方案,也可通過(guò)安裝 NPM Pageage 的方式安裝依賴。

通過(guò) script 引入:

通過(guò) npm 安裝:

$ npm i faked --save-dev

CommonJs 方式引用

const faked = require("faked");

ES6 Modules 方式引用

import faked from "faked"
三、基本使用

通過(guò) faked.when 方法你幾乎就可以使用 faked 的所有功能了,盡管 faked 還提供了一組「快捷方法」,faked.when 方法說(shuō)明如下:

//指定單一 Http Method
faked.when(, , );

//指定多個(gè) Http Method
faked.when(, , );

示例,模擬一個(gè)獲取用戶信息的接口,參考如下代碼:

faked.when("get","/user/{id}", function(){
  this.send({name:"Bob"});
});

每一個(gè) handlerthis 就是當(dāng)前請(qǐng)求上下文對(duì)象,對(duì)象有如下主要成員:

this.send(data, status, headers) 方法,用于響應(yīng)一個(gè)請(qǐng)求,status 默認(rèn)為 200

this.params 路由參數(shù)對(duì)象,用于訪問(wèn)路由模式中的「路由參數(shù)」,如上邊示例中的 id

this.query 解析查詢字符串對(duì)應(yīng)的對(duì)象,比如 ?name=bob 可以通過(guò) this.query.name 訪問(wèn)

this.body 請(qǐng)求的主體內(nèi)容,通常會(huì)是一個(gè) json 對(duì)象,它取決于發(fā)起的請(qǐng)求。

除了使用 send 方法,還可以直接「返回」數(shù)據(jù),參考如下代碼:

faked.when("get","/user/{id}", function(){
  return {name:"Bob"};
});

當(dāng)然,在有「異步處理」時(shí)你也可以返回一個(gè) promise 對(duì)象或像上邊那樣用 send 方法。如果你只想 mock 數(shù)據(jù),還可以使用簡(jiǎn)化寫(xiě)法,參考如下代碼:

faked.when("get","/user/{id}", {name:"bob"});
四、快捷方法

faked 還基于 when 方法提供了一組快捷方法,對(duì)應(yīng)常用的 Http Methods,包括:

get, post, put, delete, options, patch, head, copy, link, unlink, lock, unlock, view

faked.get 寫(xiě)一個(gè)示例:

faked.get("/user/{id}",function(){
  this.send({name:"Bob"});
});

其它快捷方法和 faked.get 用法完全一致。

五、路由系統(tǒng)

在編輯 Mock API 時(shí), faked 提供了路由支持,如上邊看到的 /user/{id},就是一個(gè)路由「匹配模式」,其中 {id} 是一個(gè)路由參數(shù),當(dāng)多個(gè)路由同時(shí)匹配請(qǐng)求的 URL 時(shí),只會(huì)觸發(fā)第一個(gè)執(zhí)行,不同的 Http Method 的 URL 匹配模式可以相同,并不會(huì)沖突。路由參數(shù)還可以加「限定表達(dá)式」,參考如下代碼:

// User Id 只能是數(shù)字
faked.get("/user/{id:d+}", {name:"test"});
六、模擬網(wǎng)絡(luò)延時(shí)

有時(shí)候,我們希望 Mock API 能延時(shí)響應(yīng)數(shù)據(jù),以模擬「網(wǎng)絡(luò)延時(shí)」,faked 目前支持固定的「延時(shí)設(shè)置」,參考如下代碼:

const faked = require("faked");

//所有的請(qǐng)求都將被延時(shí) 2 秒種再響應(yīng)用 mock 數(shù)據(jù)
faked.delay = 2000; 

當(dāng) delay 設(shè)置 0 時(shí),將禁用延時(shí)。

七、設(shè)置超時(shí)時(shí)間

faked 還可設(shè)置 Mock API 的最大響應(yīng)時(shí)間,這項(xiàng)設(shè)置存在的意義還在于「所有 Mock API 的 Handler 默認(rèn)都是異步的,如果忘記「返回或 Send」一個(gè)響應(yīng)結(jié)果,請(qǐng)求將會(huì)被一直掛起,有了超時(shí)設(shè)置,超時(shí)時(shí)將會(huì)拋出一個(gè)錯(cuò)誤,方便定位問(wèn)題」,參考如下代碼:

const faked = require("faked");

//在超過(guò) 8 秒未響應(yīng)數(shù)據(jù)時(shí),將會(huì)打印一個(gè)錯(cuò)誤消息
faked.timeout = 8000; 

超時(shí)設(shè)置和延時(shí)設(shè)置并不會(huì)相互影響,超時(shí)計(jì)算是從延時(shí)結(jié)束后開(kāi)始的。

八、JSONP 處理

faked 除了能 mock 常規(guī)的 ajaxfetch 請(qǐng)求,還能 mock 常常用來(lái)處理跨域問(wèn)題的 jsonp 請(qǐng)求,faked 有兩個(gè)參數(shù)用于配置 jsonp,參考如下代碼:

//指定服務(wù)端用于獲取「回調(diào)函數(shù)名」的 「QueryString 參數(shù)」
faked.jsonp.param = "callback"; //默認(rèn)值為 callback 和 jQuery 一致

//有些 jsonp 服務(wù)可能是固定了「回調(diào)函數(shù)名」,可以這樣設(shè)定
faked.jsonp.callback = "your-callbak-name"; 
九、注意事項(xiàng)

faked 是一個(gè)「輔助開(kāi)發(fā)」的工具,除非有特殊需要,一般情況下它不應(yīng)出現(xiàn)在你的生產(chǎn)代碼中,所以需要注意:

請(qǐng)勿將 faked 放到「生產(chǎn)環(huán)境」的應(yīng)用或頁(yè)面中

找一個(gè)合適的你項(xiàng)目的方式?jīng)Q定什么時(shí)引用 faked

比如,在 webpak 中,可以根據(jù)環(huán)境變量決定入口文件,并只在 mock 的入口文件中引用 faked,示例:

webpack.config.js

module.exports = {
  entry: {
    //根據(jù) NODE_ENV 決定是 index.js 還是 index.mock.js
    bundle: `./src/index${NODE_ENV=="mock"?".mock":""}.js`
  },
  output: {
    path: "./dist/",
    filename: `./[name]${NODE_ENV == "prod"?".min":""}.js`
  },
  devtool: "source-map",
  module: {
    loaders: [...]
  },
  plugins: [...]
};

然后,在 index.mock.js 中這樣寫(xiě):

require("./mock")
require("./index");

用于存放的 mock 代碼的 mock.js 可能是這樣的:

const faked = require("faked");

faked.get("/user/{id}",function(){
  this.send({name:"Bob"});
});

當(dāng)然,你可以根據(jù)實(shí)際情況,安排你的文或目錄結(jié)構(gòu)。

-- END --

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/82173.html

相關(guān)文章

  • mock service系列】Online mock service or API by Sand

    摘要:沙箱,第一反應(yīng),但并不是。為避免誤解,下文中所有提到都是指這個(gè)工具,不是沙箱。做什么的,根據(jù)其官網(wǎng)上的描述可以理解為快速生成,即時(shí)部署,協(xié)作構(gòu)建并集成了調(diào)試工具。對(duì)個(gè)人而言,強(qiáng)烈推薦給入門(mén)的人。 Sandbox--沙箱,第一反應(yīng),但sorry并不是。 sandbox 這個(gè)詞大家并不陌生,但貌似國(guó)內(nèi)的技術(shù)share中很少看到有提到這個(gè)工具的。為避免誤解,下文中所有提到sandbox都是指...

    zgbgx 評(píng)論0 收藏0
  • 用Jasmine和Sinon測(cè)試Backbone應(yīng)用 (譯)

    摘要:框架本身可以很好地支持自下而上的單元測(cè)試。在中,這些原因可以分為性能真實(shí)的操作,依靠定時(shí)行為及網(wǎng)絡(luò)活動(dòng)減慢了測(cè)試隔離單元測(cè)試應(yīng)把重點(diǎn)放在小的一塊功能成為可能,并解耦不可靠的或低依賴使用對(duì)象是擁抱和的基本組成部分。 最近在慢慢深入Backbone,也試著寫(xiě)一些測(cè)試,找一些合適的文檔來(lái)學(xué)習(xí)。于是就找到了一個(gè)系列的文章 : Testing Backbone applications with...

    ralap 評(píng)論0 收藏0
  • 前端單元測(cè)試初探

    摘要:本文只討論單測(cè)的范疇,對(duì)集成測(cè)試有興趣的話,可以看下的集成測(cè)試代碼。前端單測(cè)現(xiàn)狀測(cè)試本質(zhì)上就是假定一個(gè)輸入,然后判斷得到預(yù)期的輸出。 原文發(fā)于我的博客:https://github.com/hwen/blogS... 要不要寫(xiě)單測(cè)? 關(guān)于這個(gè) cnode 上就有個(gè)很有意思的討論 做個(gè)調(diào)查,你的 Node 應(yīng)用有寫(xiě)單測(cè)嗎? 看完這個(gè)應(yīng)該會(huì)有結(jié)論?如果沒(méi)有,就回帖跟別人探討下~ 測(cè)試 測(cè)試...

    isLishude 評(píng)論0 收藏0
  • 使用API自動(dòng)生成工具優(yōu)化前端工作流

    摘要:在工作中,我們的前端工作流一般開(kāi)始于前后端協(xié)商好文檔之后,再針對(duì)這個(gè)文檔做模擬數(shù)據(jù),然后用做好的進(jìn)行開(kāi)發(fā),后端開(kāi)發(fā)完畢之后再改一下數(shù)據(jù)的切換到正式進(jìn)行聯(lián)調(diào)如下本文介紹的一個(gè)工具或者說(shuō)方法,來(lái)將這個(gè)工作流優(yōu)化一下,也是我平時(shí)工作正在用的方法, 在工作中,我們的前端工作流一般開(kāi)始于前后端協(xié)商好Api文檔之后,再針對(duì)這個(gè)Api文檔做mock模擬數(shù)據(jù),然后用做好的mock進(jìn)行開(kāi)發(fā),后端開(kāi)發(fā)完畢...

    GeekQiaQia 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<