node+koa 데이터 mock 인터페이스 구현 방법
디 렉 터 리 구조
// server.js
const Koa = require('koa');
const Router = require('koa-router');
const qs = require('qs');
const assert = require('assert');
const app = new Koa();
const router = new Router();
/**
*
* @param {request} page
* @param {request} limit
* @param {response} errno 0 ==> 1 ==>
* @param {response} hasMore
*/
let listData = require('./mock/list/list.js');
router.get('/api/getlist/:page/:limit', function (ctx, next) {
const page = ctx.params.page;
const limit = ctx.params.limit;
const maxPage = listData.length / limit;
//
let res = {
errno: 0,
data: {
hasMore: true,
data: []
}
};
//
if ((page*1 + 1) >= maxPage) {
res.data.hasMore = false;
}
res.data.data = listData.slice(page*limit, page*limit + limit);
ctx.body = res;
});
/**
*
* @param {request} id id
*/
const detailData = require('./mock/detail/detail.js');
router.get('/api/getdetail/:id', function (ctx, next) {
const id = ctx.params.id
let res = {
errno: 0,
data: {
data: []
}
}
res.data.data = detailData;
// todo...
ctx.body = res;
});
/**
*
* @param {request} id id
* @param {request} uid id
* @param {request} msg
*/
router.post('/api/comment', function (ctx, next) {
const params = qs.parse(ctx.req._parsedUrl.query);
const id = params.id;
const uid = params.uid;
const msg = params.msg;
if (id === undefined || uid === undefined || msg === undefined) {
ctx.body = {
errno: 1,
msg: ' '
}
} else {
// todo...
ctx.body = {
errno: 0,
msg: ' '
}
}
});
app
.use(router.routes())
.use(router.allowedMethods());
app.listen(3000);
console.log("server is running at http://localhost:3000/");
실제 프로젝트 에서 인 터 페 이 스 를 호출 하면 도 메 인 을 뛰 어 넘 는 문제 에 부 딪 히 고 해결 하 는 방식 은 여러 가지 가 있 습 니 다.웹 팩 에서 어떻게 설정 하 는 지 소개 합 니 다.
module.exports = {
...
devServer: {
proxy: {
// `/api` http , `localhost:3000` , koa mock
'/api': {
target: 'http://localhost:3000',
secure: false
}
}
...
}
}
프로젝트 주소:https://github.com/daijingfeng/mock-server이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Express.js에서 오류를 처리하는 간단한 방법Express에서 오류를 처리하는 여러 가지 방법이 있습니다. 이를 수행하는 일반적인 방법은 기본 익스프레스 미들웨어를 사용하는 것입니다. 또 다른 방법은 컨트롤러 내부의 오류를 처리하는 것입니다. 이러한 처리 방식...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.