Vue项目使用mockjs模拟后端接口

news/2024/12/22 1:16:08/

文章目录

    • 操作步骤
      • 1. 安装 mockjs 和 vite-plugin-mock
      • 2. 安装 axios
      • 3. 创建mock路径
      • 4. 配置 viteMockConfig
      • 5. 编写第一个mock接口
      • 6. 创建 createProdMockServer
      • 7. 配置 axios
      • 8. 编写请求接口
      • 9. 在页面中使用

操作步骤

1. 安装 mockjs 和 vite-plugin-mock

vite-plugin-mock 是 vite 提供的mock插件,配合mockjs 一起使用,比较方便。

npm install mockjs vite-plugin-mock=2.9.6

2. 安装 axios

通过axios发送请求,请求到mock的模拟接口

npm install axios

3. 创建mock路径

src 文件夹下创建 mock 文件夹,作为后续编写mock接口的路径

4. 配置 viteMockConfig

在 vite.config.js 中配置 viteMockConfig
mockPath 就是mock文件夹的路径

import { defineConfig } from 'vite'
import {viteMockServe} from 'vite-plugin-mock'// https://vitejs.dev/config/
export default defineConfig({plugins: [vue(),vueDevTools(),viteMockServe({mockPath: './src/mock'})],resolve: {alias: {'@': fileURLToPath(new URL('./src', import.meta.url))}}
})

5. 编写第一个mock接口

mock文件夹下新建一个 js 文件,如user.js ,作为专门编写与用户相关的接口数据,内容如下:

export default[{url: '/mock/user/test',method: 'get',response: () => {return {code: 200,msg: 'ok',data: 'hello world'}}}
]

该文件创建了一个模拟接口,地址为/mock/user/test

6. 创建 createProdMockServer

mock文件夹下创建一个index.js 文件,内容如下:

import {createProdMockServer} from 'vite-plugin-mock/es/createProdMockServer'
// 导入上面写的user.js
import userModule from './user'export function setupProdMockServer(){createProdMockServer([...userModule])
}

7. 配置 axios

创建 src/utils/system/request.js 文件用来全局配置axios,内容如下:

// 在这个文件中配置axios,以及拦截请求
import axios from 'axios'// const baseURL = import.meta.env.VITE_BASE_URLconst service = axios.create({bbaseURL: '/mock',timeout: 5000
})// 拦截器,错误处理配置export default service

8. 编写请求接口

创建src/api/user.js 文件作为请求用户相关数据的文件,内容如下:

// 导入配置过的 axios
import request from '@/utils/system/request'export function loginApi(data){return request({url: '/user/test',method: 'get',baseURL: '/mock',data})
}

该文件创建了一个请求接口loginAPi ,用来请求之前创建的mock接口地址

9. 在页面中使用

首先在需要的页面导入请求的接口:

import { loginApi } from "../../api/user.js";

然后以Promise的形式使用

onMounted(() => {loginApi({}).then(res => {console.log(res)})
})

如果控制台打印出结果,则说明配置成功


http://www.ppmy.cn/news/1474156.html

相关文章

谷粒商城学习笔记-20-分布式组件-SpringCloud Alibaba简介

文章目录 一,微服务组件来源介绍二,SpringCloud Alibaba简介1,简介2,SpringCloud 的几大痛点3,SpringCloud Alibaba 的优势, 三,谷粒商城项目选型列表1,注册中心-Nacos2,配置中心-Na…

如何实现跨域

目录 JSONP (JSON with Padding) CORS (Cross-Origin Resource Sharing) Nginx代理 Node.js中间件代理 Vue axios实现(或其他前端HTTP库) 原生JS、jQuery Ajax等其他方式 跨域实现是Web开发中常见的需求,主要涉及到不同源(协议、域名、端口三者之一不同即为不同源)之…

NXP i.MX8系列平台开发讲解 - 3.18 Linux tty子系统介绍(一)

专栏文章目录传送门:返回专栏目录 Hi, 我是你们的老朋友,主要专注于嵌入式软件开发,有兴趣不要忘记点击关注【码思途远】 目录 1. TTY 起源 2. Linux 系统中的TTY 2.1 Linux TTY 设备形式 2.2 Linux TTY framework 2.3 驱动核心相关文件…

206. 反转链表 (Swift 版本)

题目 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 解题 /*** Definition for singly-linked list.* public class ListNode {* public var val: Int* public var next: ListNode?* public init() { self.val 0; self.…

沙龙回顾|MongoDB如何充当企业开发加速器?

数据不仅是企业发展转型的驱动力,也是开发者最棘手的问题。前日,MongoDB携手阿里云、NineData在杭州成功举办了“数据驱动,敏捷前行——MongoDB企业开发加速器”技术沙龙。此次活动吸引了来自各行各业的专业人员,共同探讨MongoDB的…

鸿蒙开发:Universal Keystore Kit(密钥管理服务)【加密导入密钥(C/C++)】

加密导入密钥(C/C) 以加密导入ECDH密钥对为例,涉及业务侧加密密钥的[密钥生成]、[协商]等操作不在本示例中体现。 具体的场景介绍及支持的算法规格。 在CMake脚本中链接相关动态库 target_link_libraries(entry PUBLIC libhuks_ndk.z.so)开发步骤 设备A&#xf…

C# AOP面向切面编程

AOP(Aspect-Oriented Programming,面向切面编程)是一种编程范式,旨在将横切关注点(Cross-cutting Concerns)从业务逻辑中分离出来。在传统的面向对象编程中,横切关注点(如日志记录、…

elasticsearch-users和elasticsearch-reset-password介绍

elasticsearch 内置 elastic, kibana, logstash_system,beats_system 共4个用户,用途如下: elastic 账号:内置的超级用户,拥有 superuser 角色。 kibana 账号:用来连接 elasticsearch 并与之通信。Kibana 服务器以该用…