背景

祥云網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),祥云網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為祥云上千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的祥云做網(wǎng)站的公司定做!
最近做了很多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í)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
本文名稱:詳解Koa中更方便簡(jiǎn)單發(fā)送響應(yīng)的方式
URL鏈接:http://www.chinadenli.net/article36/pescsg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營(yíng)銷型網(wǎng)站建設(shè)、電子商務(wù)、動(dòng)態(tài)網(wǎng)站、商城網(wǎng)站、Google、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)