背景
最近做了很多node的后臺(tái)項(xiàng)目,寫了很多接口,但是發(fā)現(xiàn)隨著接口的慢慢增多,需要寫越來(lái)越來(lái)越多類似于下面這種代碼。
ctx.body = {  data: {    name: 'test'  },  status: {    code: 0,    message: success  }}寫成這樣還好,至少做到了所有接口返回的格式統(tǒng)一,如果沒(méi)有在這方面做規(guī)范,那么后臺(tái)的接口返回不統(tǒng)一,將會(huì)給前端帶來(lái)很多的問(wèn)題。
而且每個(gè)接口都要寫這么一大堆的代碼。感覺(jué)是個(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ò)誤信息。例如,用戶沒(méi)有權(quán)限,http的狀態(tài)碼就應(yīng)該是401,而不應(yīng)該是我們自定義的code了。
寫在后面
大家如果有更好的解決方案,希望不吝賜教。
Github傳送門koa2-response
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。
新聞熱點(diǎn)
疑難解答