您好,登錄后才能下訂單哦!
背景
最近做了很多node的后臺(tái)項(xiàng)目,寫了很多接口,但是發(fā)現(xiàn)隨著接口的慢慢增多,需要寫越來越來越多類似于下面這種代碼。
ctx.body = { data: { name: 'test' }, status: { code: 0, message: success } }
寫成這樣還好,至少做到了所有接口返回的格式統(tǒng)一,如果沒有在這方面做規(guī)范,那么后臺(tái)的接口返回不統(tǒng)一,將會(huì)給前端帶來很多的問題。
而且每個(gè)接口都要寫這么一大堆的代碼。感覺是個(gè)特別麻煩的事。
所以koa2-response就這么誕生了。其實(shí)在寫這篇文章之前,我已經(jīng)在我的項(xiàng)目里面用了一段時(shí)間了,方便了我們的操作。
安裝
npm install koa2-response
用法
const koa = require('koa'); const router = require('koa-router')(); const app = new koa(); const response = require('koa2-response'); const code = { UNKNOWN_ERROR: [1, 'Sorry, you seem to have encountered some unknown errors.'] } router .get('/', (ctx, next) => { response.success(ctx, { name: 'test' }) }) .get('/error_test', (ctx, next) => { response.error(ctx, code.UNKNOWN_ERROR); }) app.use(router.routes()); app.use(router.allowedMethods()); app.listen(3000);
就這樣很簡(jiǎn)單的就可以統(tǒng)一后端的返回?cái)?shù)據(jù),這個(gè)方法讓我在項(xiàng)目中節(jié)約了很多時(shí)間。這個(gè)中間件還是在持續(xù)更新中,現(xiàn)在已經(jīng)有的方法是response.success和response.error。我打算繼續(xù)更新一個(gè)方法叫response.throw,這可以讓后臺(tái)自定義返回的http狀態(tài)碼以及錯(cuò)誤信息。例如,用戶沒有權(quán)限,http的狀態(tài)碼就應(yīng)該是401,而不應(yīng)該是我們自定義的code了。
寫在后面
大家如果有更好的解決方案,希望不吝賜教。
Github傳送門koa2-response
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。