vite和mockjs配合使用

vite + mockjs

当后端还没准备完成之前,前端可以使用 mock 模拟后端响应,提高开发效率

1、安装插件

使用 vite-plugin-mock 插件,配合mockjs完成项目的 mock 配置

复制代码
npm install mockjs vite-plugin-mock
2、vite配置插件

vite.config.js 文件中引入对应插件

复制代码
import { viteMockServe } from 'vite-plugin-mock'

...

plugins: [
    vue(),
    viteMockServe({
       mockPath: './mock'  // mock数据所在的目录 ./mock 代表和vite.config.js同级目录即根目录
    })
]
3、mock数据编辑

根目录创建mock,mock目录下创建index.js

复制代码
import Mock from "mockjs"
export default [
  {
   url: "/login",
   method: "post",
   response: (res) => {
      return {
        status:200,
        code:1,
        result:res.body  // res.body 接口传过来的参数
      }
   },
 }
]
4、main.js 引入mock数据
复制代码
// 模拟接口mockjs
import '../mock/index'
5、配合axios使用
下载 axios
复制代码
npm install axios
封装axios

src 目录下创建utils目录,utils下创建request.js(文件命名自定义,一般为request或者http)

复制代码
import axios from 'axios'
const service = axios.create({
    baseURL:'' // mockjs 模拟数据这里必须为空,否则请求报404 
})
// 请求拦截器
service.interceptors.request.use(config=>{
    // 头部携带token
    return config;
})

// 响应拦截器
service.interceptors.response.use(res=>{
    return res;
},err=>{
    return Promise.reject(err)
})

export default service;
封装api

src 目录下新建 api 文件夹,api下创建 api.js

复制代码
import request from '../utils/request'

//  登录
export const login = (data)=>{
    return request({
        method:'post',
        url:'/login',
        data:data
    })
}
使用axios
复制代码
import {login} from '../../api/api'

const getTest = async ()=>{
    let res = await login({
        name:'张三',
        pwd:'123456'
    })
}

onMounted(()=>{
   getTest()
})
相关推荐
swipe7 分钟前
为什么 RAG 一定离不开向量检索:从文档向量化到语义搜索的工程实现
前端·llm·agent
OpenTiny社区34 分钟前
AI-Extension:让 AI 真的「看得到、动得了」你的浏览器
前端·ai编程·mcp
IT_陈寒37 分钟前
Redis缓存击穿:3个鲜为人知的防御策略,90%开发者都忽略了!
前端·人工智能·后端
竹林8182 小时前
在Web3前端用Node.js子进程批量校验钱包,我踩了这些性能与安全的坑
javascript·node.js
农夫山泉不太甜2 小时前
Tauri v2 实战代码示例
前端
yuhaiqiang2 小时前
被 AI 忽悠后,开始怀念搜索引擎了?
前端·后端·面试
红色石头本尊2 小时前
1-umi-前端工程化搭建
前端
真夜2 小时前
关于对echart盒子设置百分比读取的宽高没有撑开盒子解决方案
前端
楠木6853 小时前
RAG 资料库 Demo 完整开发流程
前端·ai编程
肠胃炎3 小时前
挂载方式部署项目
服务器·前端·nginx