Vite+Vue3使用MockJS

2024-01-01 22:44

本文主要是介绍Vite+Vue3使用MockJS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在使用Vue3开发的时候,有时候没有后端或者后端接口还没有准备好,那就需要使用Mock模拟数据便于前端开发。

现在就记录一下Vite+Vue3的环境下如果使用MockJS。

版本

  • vue 3.3.11
  • mockjs 1.1.0
  • axios 1.6.3

Mockjs配置使用

使用pnpm命令安装Mockjs

pnpm install axios
pnpm install mockjs

mock模拟接口

src目录下新建文件夹mock,并新建文件index.ts,引入mockjs

import Mock from 'mockjs'

直接在上面引入,在vscode中会报错

找不到模块“mockjs”或其相应的类型声明。ts(2307)

我是使用pnpm、vite新建的vue3项目,只需要在src目录下的vite-env.d.ts文件下,加入以下配置即可

/// <reference types="vite/client" />declare module 'mockjs'

main文件下引入mockjs

main.ts文件下引入mockjs

import './mock/index'

编写模拟接口

import Mock from 'mockjs'Mock.mock("/mock/login","post", {code: 200, token:"login success token"});Mock.mock("/mock/getGoodsList","get", {code: 200, message:"请求成功",data:[{id:1,introduce:"旺仔牛奶很好喝!!!",title:"旺仔牛奶",userId:1},{id:2,introduce:"旺旺碎碎冰很冰很好吃!!!",title:"旺旺碎碎冰",userId:1},{id:3,introduce:"喜之郎品牌很好吃!!!",title:"喜之郎",userId:1},{id:4,introduce:"卫龙辣条很好吃!!!",title:"卫龙辣条",userId:1},{id:5,introduce:"德芙巧克力很好吃!!!",title:"德芙巧克力",userId:1},{id:6,introduce:"伊利牛奶很好喝!!!",title:"伊利牛奶",userId:1}]
});

axios配置使用

配置axios

import axios from 'axios'//创建axios实例
const service = axios.create({baseURL:"/mock",timeout:5000,headers:{"Content-Type":"application/json;charset=utf-8"}
})//请求拦截
service.interceptors.request.use((config)=>{config.headers=config.headers || {}if(localStorage.getItem("token")){config.headers.token = localStorage.getItem("token") || ""}return config
})// 响应拦截
service.interceptors.response.use((res)=>{const code:number = res.data.codeif(code != 200){return Promise.reject(res.data)}return res
},(err)=>{console.log(err)
})export default service

编写axios的请求接口

import service from ".";
import { LoginData } from "../type/login";//登录接口
export function login(data:LoginData) {return service({url:"/login",method:"post",data})
}//获取商品接口
export function getGoodsList(){return service({url:"/getGoodsList",method:"get",})
}

页面中使用axios请求接口

<template><div class="login-box"><div class="login-box"><el-form ref="ruleFormRef" :model="ruleForm" status-icon :rules="rules" label-width="80px"class="login-ruleForm"><h2>后台管理系统</h2><el-form-item label="账号:" prop="username"><el-input v-model="ruleForm.username" autocomplete="off" /></el-form-item><el-form-item label="密码:" prop="password"><el-input v-model="ruleForm.password" type="password" autocomplete="off" /></el-form-item><el-form-item><el-button class="loginBtn" type="primary" @click="submitForm(ruleFormRef)">登录</el-button><el-button class="loginBtn" @click="resetForm">重置</el-button></el-form-item></el-form></div></div>
</template><script lang="ts" setup>
import { reactive,ref } from 'vue';
import { LoginData } from '../type/login';
import type { FormInstance } from "element-plus";
import { login } from "../request/api";
import { useRouter } from "vue-router";const ruleForm = reactive<LoginData>({username:"",password:""});const rules = {username: [{required: true,message: "请输入你的账号",trigger: "blur",},{min: 3,max: 10,message: "账号的长度在3到10之间",trigger: "blur",},],password: [{required: true,message: "请输入你的密码",trigger: "blur",},{min: 3,max: 10,message: "密码的长度在3到10之间",trigger: "blur",},],};const resetForm = () => {ruleForm.username = "";ruleForm.password = "";};const ruleFormRef = ref<FormInstance>();const router=useRouter()//-->$routerconst submitForm = (formEl: FormInstance | undefined) => {if (!formEl) return;// 对表单的内容进行验证// valid布尔类型,为true表示验证成功,反之formEl.validate((valid) => {if (valid) {// console.log("submit!");login(ruleForm).then((res) => {console.log(res);// 将token进行保存localStorage.setItem("token", res.data.token);// 跳转页面,首页router.push('/')});} else {console.log("error submit!");return false;}});// console.log(formEl);};
</script><style lang="scss" scoped>
.login-box {width: 100%;height: 100%;background: url('../assets/bg.jpg');padding: 1px;.login-ruleForm{width: 500px;margin: 200px auto;background-color: #fff;padding: 40px;border-radius: 20px;}.loginBtn {width: 48%;}h2 {margin-bottom: 10px;}
}
</style>

这篇关于Vite+Vue3使用MockJS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/560708

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1