前端請求接口post_前端如何優雅地模擬接口請求?(給你的代碼加點小意外)

083ca50e48d597adedc604aa615df51c.png

前言:

作為一名前端開發程序猿,每天都被產品經理催著開發,項目一啟動,產品就過來了。噓寒問暖:大胸弟,你啥時開始做啊?一般我們都會直接告訴TA,你先找接口解決數據問題。

而我們也會經常遇見“巧婦難為無米之炊”的難題,難道我們離開后端數據就不能生存啦?最近忙于某個項目,也遇到了這事,那我是怎么去解決的叻?容我娓娓道來。

所謂天才第一步,XXX啥褲。開個玩笑,我們肯定是需要先搞清楚我們想干啥。只有明確了目標,才能減少走彎路。 需求:

  • 模擬發送請求
  • 模擬數據回傳
  • 本地開發實現

這三步中,模擬發送請求,這個目標對于我們前端來說,它并不重要,后端是比較看重你給什么參數,我好還你啥數據。

所以我們前端要做好模擬數據回傳,這樣才能更好的跟后端去約定字段,數據結構相關的。有了數據,我們才能更好的去實現功能開發。

目標分析

模擬數據回傳,標準的接口組成,由兩部分組成:

  • 數據結果
  • 請求狀態

說到這里,我就忍不住的打開了瀏覽器調試模式。我正大光明的瞄了眼知乎的請求,比如這個接口:

https://www.zhihu.com/api/v4/creator/apply

a682da8fd04ebcc41e35c606442229aa.png

那我們到底本地怎么模擬數據了?

解決問題

到了最后一步,咱們猿類最關心的問題,你說你洋洋灑灑說了一大堆廢話,你倒是上代碼啊!(我等著ctrl+c, ctrl+v 訥。我不創造代碼,我只是代碼的搬運工。)

廢話就不扯那個淡,首先最直接方法,固定寫好。

const result = {creator_status: 1entrance_msg: ""level: 1notification: {apply_pass: 0}status: 2
}

有人說,這個我也會,我還會給他加個 setTimeout 函數,更加像:

setTimeout(() => {this.setState({...result,})
}, 2000)

嘿,突然發現自己是個天才,簡直跟接口回調一毛一樣。

喂,醒醒....咋能不能有點追求。

哦,是不是嫌數據少了,我再復制幾次。

low, 咱能不能對自己要求高一點。

我們應該讓數據更加可變,并且還可以模擬異步調用。所以,我們來改造一下。

首先用 js 實現一個概率函數,對,就是那個隨機抽獎函數。網上隨手找了一個:

random = (targetArr, probArr) => {let sum = 0,factor = 0,random = Math.random();for (let i in probArr) {sum += probArr[i];}random *= sum;for (let i in probArr) {factor += probArr[i];if (random <= factor) {return targetArr[i];}}return null;}

這個簡單,不就是把這個隨機函數加到數據上去就好啦。

low, 咱能不能再高級點,好歹也是前端高級猿類。

我們可以這樣:(還可以刺激地加點錯誤數據,吃不吃雞,意不意外,驚不驚喜。翻譯翻譯,啥叫驚喜,來,咱看一看。)

getResult = () => {return {creator_status: this.random([1, 2, 3, 4], [0.2, 0.2, 0.1, 0.5]),entrance_msg: this.random(['', void 0, '恭喜你中獎啦!', 'null'], [0.4, 0.1, 0.3, 0.2]),level: this.random([1,2], [0.5, 0.5]),notification: this.random([{apply_pass: this.random([0, 1], [0.2, 0.8])}, {}], [0.6, 0.4])}
}fetchData = (size) => {return new Promise((resolve, reject) => {const randTime = Math.random() * 2;const status = this.random([0, 1, 2], [0.2, 0.2, 0.6]);setTimeout(() => {if (status < 2) {reject({status,dataList: [],});} else {resolve({status,dataList: [...Array(size)].map(i => this.getResult()),});}}, randTime * 1000);});
}

這樣就大功告成啦!完美收官,看看結果把:

fetchData(5).then(res => console.log(JSON.stringify(res, '', 4))).catch(e => console.warn(e))
// 輸出結果
{"dataList": [{"creator_status": 3,"entrance_msg": "null","level": 1,"notification": {"apply_pass": 1}},{"creator_status": 4,"entrance_msg": "","level": 1,"notification": {}},{"creator_status": 1,"entrance_msg": "恭喜你中獎啦!","level": 1,"notification": {}},{"creator_status": 2,"entrance_msg": "null","level": 2,"notification": {}},{"creator_status": 4,"entrance_msg": "恭喜你中獎啦!","level": 2,"notification": {"apply_pass": 1}}],"status": 2
}

寫在最后

一定要多跑幾次哦。有可能結果是一樣的,不要驚訝不要彷徨!多跑幾次就會出現其他結果啦!

其實咱也不用這么大費周章,現成的數據模擬就有:EasyMock 等等。只是我只需要前期用用,而且是在內部使用,所以沒必要去接入這個,自己就寫點數據玩玩而已啦!

歡迎提問和指正錯誤,我會第一時間和您取得溝通,下期我們再會吧!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/373647.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/373647.shtml
英文地址,請注明出處:http://en.pswp.cn/news/373647.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

cron表達式詳解

Cron表達式是一個字符串&#xff0c;字符串以5或6個空格隔開&#xff0c;分為6或7個域&#xff0c;每一個域代表一個含義&#xff0c;Cron有如下兩種語法格式&#xff1a; Seconds Minutes Hours DayofMonth Month DayofWeek Year或 Seconds Minutes Hours DayofMonth Month …

將Ehcache添加到Openxava應用程序

介紹 本文介紹如何在Openxava應用程序上快速啟用Ehcache&#xff0c;從而提高性能。 查看實體及其圖時&#xff0c;將加載關系。 添加第二級緩存可加快關聯元素的檢索速度&#xff0c;因為已加載的元素是從緩存而不是數據庫中檢索的。 最終&#xff0c;該頁面解釋了分鐘項目如…

java mongodb 返回所有field_JAVA高級之反射

更多精彩&#xff0c;請點擊上方藍字關注我們&#xff01;今天跟大家分享JAVA高級之反射的知識。一、什么是反射反射就是把Java類中的各個成分映射成一個個的Java對象。即在運行狀態中&#xff0c;對于任意一個類&#xff0c;都能夠知道這個類的所以屬性和方法&#xff1b;對于…

Linux入門筆記——cal、date、free、clear、history、man、whatis、uname

1、cal 顯示日歷2、date 顯示系統當前的日期和時間3、df查看磁盤剩余空間的數量&#xff0c;常用參數 -h &#xff08;human&#xff09;人性化顯示內容4、free顯示空閑內存的數量&#xff0c;常用參數 -h &#xff08;human&#xff09;人性化顯示內容5、clear清除控制終端顯示…

使用ASM 4處理Java類文件–第一部分:世界,您好!

什么是ASM &#xff1a;ASM是一個用于處理Java字節碼的開源Java庫。 因此&#xff0c;它具有與Apache BCEL相同的目的。 由于本文假定讀者具有Java類文件格式的某些知識&#xff0c;因此建議在此處進行閱讀。 那么它與BCEL有何不同&#xff1f; 首先&#xff0c;它允許使用事件…

(轉)C#程序開發中經常遇到的10條實用的代碼

原文地址&#xff1a;http://www.cnblogs.com/JamesLi2015/p/3147986.html 1 讀取操作系統和CLR的版本 OperatingSystem os System.Environment.OSVersion; Console.WriteLine(“Platform: {0}”, os.Platform); Console.WriteLine(“Service Pack: {0}”, os.ServicePack); …

Ueditor的配置及使用

Ueditor官網&#xff1a;http://ueditor.baidu.com/website/ &#xff08;項目需要JSP版本&#xff1a;UTF-8版&#xff09; 1.配置 <script type"text/javascript" charset"utf-8">window.UEDITOR_HOME_URL "${ctx}/assets/plugins/uedi…

努比亞z17s刷原生安卓_電腦運行手機APP,不會沒關系,我推薦你使用顯卡服務器運行安卓模擬器...

很多人都想用電腦端運行手機APP&#xff0c;但是又不知道怎么操作。縱橫170yun小編推薦大家使用顯卡服務器&#xff0c;在顯卡服務器上運行安卓模擬器。讓你輕輕松松在電腦端運行手機APP&#xff0c;甚至還可以多開噢 。如果你的電腦沒有顯卡&#xff0c;也沒有關系&#xff0c…

Linux入門筆記——系統目錄結構

目錄 評論 / 根目錄&#xff0c;萬物起源。 /bin 包含系統啟動和運行所必須的二進制程序。 /boot 包含 Linux 內核&#xff0c;最初的 RAM 磁盤映像&#xff08;系統啟動時&#xff0c;由驅動程序所需&#xff09;&#xff0c;和 啟動加載程序。 有趣的文件&#xff1a; /boot/…

線程故事:關于健壯的線程池

我的主題系列的另一個博客。 這次是關于線程池&#xff0c;尤其是可靠的線程池設置。 在Java中&#xff0c;線程池由Java 5中引入的ThreadPoolExecutor類實現。該類的Javadoc組織得很好。 因此&#xff0c;我不遺余力地在此處進行概述。 基本上&#xff0c; ThreadPoolExecutor…

css縮寫

顏色&#xff1a; 16進制的色彩值為六位數&#xff0c;如果每兩位的值相同&#xff0c;可以縮寫一半。 如&#xff1a;#000000#000&#xff1b; #223344#234&#xff1b; 盒子的尺寸&#xff1a; 如margin:value; 一個值表示所有邊&#xff0c;兩個值表示上下&#xff0c;左右&…

win10改成ubundu主題_如何將ubuntu引導win10,修改為win10引導ubuntu

、首先用LiveCD進入ubuntu2、打開終端&#xff0c;輸入&#xff1a;fdisk -l 查看自己linux的分區情況&#xff0c;我的分了4個區&#xff0c;swap&#xff0c;boot&#xff0c;/&#xff0c;home&#xff0c;對應的分別是&#xff1a;/dev/sda9 swap/dev/sda10 boot/dev/sda11…

Linux入門筆記——文件操作命令1

pwd Print name of current working directory&#xff08;打印出當前工作目錄名&#xff09; cd Change directory&#xff08;更改目錄&#xff09;例子&#xff1a;cd 更改工作目錄到你的家目錄&#xff08;和cd ~命令的運行結果是等同的 &#xff09;cd - 更…

使用MJRefresh自定義下拉刷新,上拉加載動畫

有時候我們需要自己設置下拉刷新,上拉加載動畫的實現,這里主要是記錄下使用MJRefresh自定義下拉刷新,上拉加載動畫..... 下拉刷新我們只需要繼承MJRefreshGifHeader即可: 實現代碼如下: - (void)prepare{[super prepare];self.stateLabel.hidden NO;self.lastUpdatedTimeLabel…

2.mybatis入門實例 連接數據庫進行查詢

1.新建項目&#xff0c;添加mybatis和mysql的jar包 2.在mysql中新建表user[id,name,age] CREATE TABLE users (id int(11) NOT NULL auto_increment,NAME varchar(50) default NULL,age int(11) default NULL,PRIMARY KEY (id)) ENGINEInnoDB DEFAULT CHARSETutf8 3.新建User類…

使用JacpFX和JavaFX2構建富客戶端

創建快速且可擴展的桌面客戶端始終是一個挑戰&#xff0c;特別是在處理大量數據和長時間運行的任務時。 盡管Eclipse RCP和Netbeans RCP是已建立的平臺&#xff0c;但其想法是建立一個輕量級的框架來異步處理組件&#xff0c;類似于Web組件。 開發人員在線程主題上的工作應較少…

lob移表空間 oracle_Oracle數據庫(1)Oracle體系結構概述(一)

Oracle數據庫的體系結構主要包括&#xff1a;物理存儲結構、邏輯存儲結構、內存結構和實例進程結構。了解了Oracle的體系結構&#xff0c;就可以對Oracle數據庫有一個整體認識&#xff0c;這樣有利于后續Oracle的學習。下面我們分別來了解邏輯存儲結構、物理存儲結構、內存結構…

Linux入門筆記——文件操作命令2

cp Copy files and directories&#xff08;復制文件和目錄&#xff09; cp 選項&#xff1a; 選項 意義 -a, --archive 復制文件和目錄&#xff0c;以及它們的屬性&#xff0c;包括所有權和權限。 通常&#xff0c;復本具有用戶所操作文件的默認屬性。 -i, --interactive 在…

java 對象的上轉型對象(父類)

Example5_10.java class 類人猿 {void crySpeak(String s) {System.out.println(s); } } class People extends 類人猿 {void computer(int a,int b) { int ca*b;System.out.println(c); }void crySpeak(String s) {System.out.println("***"s"***"); }…

EnglishLeaning

今天看了些hadoop官方reference感覺自己詞匯量和語法真是又回到解放前了。于是&#xff0c;痛下決心要好好學習英語。找到了一些學習的方法&#xff0c;自己記錄下來&#xff0c;也和大家一起借鑒 努力目標&#xff1a; 掌握大量的計算機英語術語和縮略語&#xff1b;熟練掌握計…