搭建 Mock 服务,实现前端自调

现在项目都是前后端分离的了,而对于个人开发来说,尤其对于前端工程师来说,前端开发开发需要调用接口,需要数据。不可能这时去开发一个后端再返回来接着开发,所以搭建 Mock 服务,实现前端自调是非常重要的,本章内容由此而来,记录自己的学习搭建过程。

使用node.js和mock.js搭建 Mock 服务

使用 koa 、 koa-router 搭建路由和监听服务

nodemon 监听更新并重载

复制代码
const Koa=require('koa');
const Router=require('koa-router');

const mockList=require('./mock/index')

const app=new Koa();
const router=new Router();

async function getRes(fn){
    return new Promise((resolve)=>{
        setTimeout(()=>{
            const res=fn()
            resolve(res)
        },1000)
    })
}

// 注册路由
mockList.forEach(item=>{
    
    const {url, method, response} = item;
    router[method](url,async ctx=>{
        const res= await getRes(response)
        ctx.body=res;
    })
})

app.use(router.routes())
app.listen(3005)



"dev": "nodemon index.js"

模拟网络请求的加载状态,1s

复制代码
async function getRes(fn){
    return new Promise((resolve)=>{
        setTimeout(()=>{
            const res=fn()
            resolve(res)
        },1000)
    })
}

然后就需要解决跨域问题了。

vite就只需要在vite.config.js中配置

复制代码
server: {
      proxy: {
        "/api": {
          target: "http://localhost:3005", // 后端接口地址
          changeOrigin: true, // 是否更改 origin 头
        },
      },
    },

webpack的比较复杂好像,需要用到craco,有用过朋友可以说一下,0.o

最终结果:

后面随着项目开发,遇到新问题,再回来记录。

相关推荐
鹏多多2 小时前
解锁flutter弹窗新姿势:dialog-flutter_smart_dialog插件解读+案例
前端·flutter·客户端
IT_陈寒2 小时前
Redis 7.0的这个新特性让我处理百万级QPS轻松了50%,你可能还不知道!
前端·人工智能·后端
2301_796512522 小时前
Rust编程学习 - 如何快速构建一个单线程 web server
前端·学习·rust
蒜香拿铁2 小时前
Angular【核心特性】
前端·javascript·angular.js
天天向上10242 小时前
vue3 css使用v-bind实现动态样式
前端·css·vue.js
艾小码2 小时前
前端新手必看!困扰90%人的10个JavaScript问题,一次性帮你解决
前端·javascript
xixixin_5 小时前
【React】为什么移除事件要写在useEffect的return里面?
前端·javascript·react.js
嘗_5 小时前
react 源码2
前端·javascript·react.js
我只会写Bug啊9 小时前
Vue文件预览终极方案:PNG/EXCEL/PDF/DOCX/OFD等10+格式一键渲染,开源即用!
前端·vue.js·pdf·excel·预览
扯蛋43810 小时前
LangChain的学习之路( 一 )
前端·langchain·mcp