如何在Vue项目中使用Mock模拟数据?

前言:

在项目开发流程中,在开发工作开始之前,一般会有一个接口文档产出的过程:也就是依据设计文档给出响应的接口细节,方便前端mock数据;那如何更好的使用Mock来模拟数据,是一个优秀的前端必须要掌握的技能(PS:避免成为背锅侠)!

1.什么是联调?

首先,你要了解什么是联调?在开发中起什么作用?

现在的开发基本都是前后端分离的,当后端还没有提供接口的时候,前端需要的数据从哪里来呢,就只能自己造假数据写死了。当后端接口做好后,前端所需要的数据就需要替换成后端提供的数据了。这个时候就需要进行一个前后端的调试,我们会把这个过程叫做前后端接口联调

场景:

在一般的开发场景中,后端负责写接口,前端负责调用接口。然而通常情况下,前端开发页面时,后端还未写好接口,前端可以先自己”模拟“接口,等到后端写好接口时,前端才能真正的去调用后端的接口。这时候需要验证调试内容,例如:接口中URL是否正确,以及前端传的参数和后端返回的数据是否正确等,这个验证数据和功能有没有误的过程就是联调。

作用:

前端界面的展示,需要服务端从数据库查找数据并通过接口返回给前端,联调的目的是测试前后端的数据格式 / 数据流 /参数值是否正确,保证接口能正常获取和返回正确的数据,支持对应产品功能的实现。

  • 联调是前后端一起见证靠谱的测试结果
  • 给需求方提供一个正确的需求验证环境
  • 尽早暴露前后端实现的问题

2.什么是Mock?

通常意义的mock指的就是mock server,模拟服务端返回的接口数据,用于前端开发,第三方接口联调。

简单来说就是使用mockjs用来模拟产生一些虚拟的数据,可以让前端在后端接口还没有开发出来时独立开发。我们可以使用真实的url,mockjs可以拦截ajax请求,返回设定好的数据。

在这里插入图片描述

场景:

  • 前后端开发进度不一致,前端开发速度快于后端,需要一个假的接口用于模拟后端返回。
  • 项目需要用到第三方接口,如果第三方接口未开发好,或者第三方接口没有测试环境,为了保证进度,所以需要模拟接口用于调试。

4.怎么使用Mock?

官网地址:http://mockjs.com/

3.1 使用方式

1)在vue-cli/vite项目搭建后,安装axios和mockjs

npm install -S axios
npm install -D mockjs
  1. 在util文件(通常情况下)配置axios和mock
  • axios配置,并在main.js中引入
//http.js文件内容
import axios from 'axios'

axios.interceptors.response.use(res=>res.data)

export default axios
  • mock配置,并在main.js中执行
//可以在mock.js文件中模拟数据
//如果引入出现... 执行npm i --save-dev @types/mockjs 

// 引入mockjs
import Mock from 'mockjs'

// mock方法--三个参数
  // 1. 拦截请求地址
  // 2. 请求方式
  // 3. 返回数据
    // 形式:1直接返回数据  2函数返回数据

// 定义全局数据
let arr =[]

// 定义函数-生成数据
// 函数返回数据--方便进行增删改查
const createNews=()=>{
  let newlist = []
  for(let i =0;i<5;i++){
    newlist.push({
      // 生成的数据
      cname:Mock.Random.cname()
    })
  }
  return newlist
}

arr= createNews()

// 定义函数-处理新增数据
const handleAddName = (opt)=>{
  // post传递过来的参数
  // console.log(opt.body) //json字符串 需要转成对象
  let {keyWords} = JSON.parse(opt.body)
  console.log(keyWords)
  arr.push({cname:keyWords})
  return arr
}

// 定义函数-删除数据
const handleDeleteName =(opt)=>{
  // 通过opt.url截取字符串传递过来的参数
  // console.log(opt.url)
  let index = opt.url.split('=')[1]
  // console.log(index)
  arr.splice(index,1)
  // console.log(arr)
  return arr
}

// 查询接口--get
Mock.mock('/mock/news','get',arr)
// 新增接口--post
Mock.mock('/mock/addNews','post',handleAddName)
// 删除接口--delete(请求的查询参数拼接在请求路径中的,需要对路径进行处理,使用正则,只要是符合校验的进来进行操作)
Mock.mock(/^\/mock\/deleteNews/,'delete',handleDeleteName)



// 直接返回数据
// Mock.mock('/mock/news','put',{
// 属性 list 的值是一个数组,其中含有 1 到 10 个元素
//   "list|10":[
//     {
//       "fname":"@cfirst()",
//       "lname":"@clast()",
//       "avatar":"@image('100x100','pink','#fff','png','Hello')",
//       "info":"@cparagraph()",
//       "age":"@integer(0,100)",
//       "address":"@county(true)",
//       "yzm":"@string('number',6)"
//     }
//   ]
// })
  • main.js文件
//main.js文件内容
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import router from './router/index.js'
//引入axios
import axios from './util/http.js'
const app = createApp(App)

// 执行mockjs文件
import './util/mock.js'

//全局提供
app.provide('$axios',axios)

app
.use(router)
.mount('#app')
  • 模拟获取到的数据如下图(具体可根据官网提供的示例,按需使用):
在这里插入图片描述
  1. 调用接口请求数据,渲染数据
<template>
  <h3>Mock模拟数据</h3>
  <ul>
    <li v-for="item,index in list" :key="item">
      <h4>{{item.fname}}</h4>
      <h4>{{item.cname}}</h4>
      <input type="button" value="删除Name" @click="deleteName(index)">
    </li>
    <input type="text" v-model="addNameInp">
    <input type="button" value="新增Name" @click="addNameBtn">
  </ul>
</template>

<script setup>
// 引入
import {ref,reactive,toRefs,inject,onMounted} from 'vue'
// 使用axios
const $axios = inject('$axios')
// 数据
const data = reactive({
  list:[]
})
// 解构list --使用toRefs变成响应式
const {list} = toRefs(data)
// 新增的名字的value
const addNameInp = ref('')
// 新增按钮
const addNameBtn = async()=>{
  // 请求数据
  let res = await $axios.post('/mock/addNews',{
    keyWords:addNameInp.value
  })
  // 清空输入框
  addNameInp.value=''
  data.list = res
}
// 删除按钮
const deleteName =async(index)=>{
  let res = await $axios.delete('/mock/deleteNews',{
    params:{
      index:index
    }
  })
  data.list=res
}

onMounted(async()=>{
  // 请求数据
  let res = await  $axios.get('/mock/news')
  console.log(res)
  // data.list  = res.list
  data.list= res
})
</script>
image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容