我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue-cli如何实现异步请求返回mock模拟数据

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue-cli如何实现异步请求返回mock模拟数据

这篇文章主要为大家展示了“vue-cli如何实现异步请求返回mock模拟数据”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue-cli如何实现异步请求返回mock模拟数据”这篇文章吧。

  在前后端分离开发的过程中,前端开发过程中,页面的数据显示一般都是写死的静态数据,也就是没有经过接口,直接写死在代码中的,在后端给出接口后,再替换为接口数据,为了减少对接成本,mock就出现了。通过预先跟服务器端约定好的接口,模拟请求数据甚至逻辑,能够让前端开发更加独立自主,不会被服务端的开发所阻塞。

  网上有不少使用mockjs模拟数据的文章,但基本都是本地拦截请求返回数据,在network中没有发出任何的请求,本地调试起来很不好,只能通过console.log来调试。为了实现真正的异步请求,那么就需要真正的服务器接口,而在开发vue-cli项目时,本地开发运行启动命令后,实际就是启动了一个本地服务器,那么只要把接口地址都在本地服务器中配置并使用mock返回数据就可以实现真正的异步请求了,这样调试就和真正的请求一模一样了。

开始实现

  因为是vue-cli项目,请先安装node和npm。

  1、首先,需要全局安装vue-cli:

 1、首先,需要全局安装vue-cli:

> npm install -g @vue-cli

  2、创建vue-cli项目:

> vue create vue-mock

  创建成功后进入项目根目录,运行npm run serve启动,应该可以成功访问vue示例页面  

  本示例使用的版本是vue-cli 4.5.13、vue3、webpack4,如果发现某个配置不生效,请留意是否已经被废弃。

  3、安装axios

> npm install axios -S

  4、main.js添加aixos,修改如下

// main.jsimport { createApp } from 'vue'import App from './App.vue'import axios from 'axios'const vueApp = createApp(App)vueApp.config.globalProperties.$axios = axios // vue3与vue2的区别,不再是通过prototypevueApp.mount('#app')

  5、安装mockjs

> npm install mockjs -D

  6、在根目录新建mock文件夹,在mock文件夹下新建index.js文件,并在main.js中引入index.js,代码如下:

// mock/index.jsimport Mock from 'mockjs'Mock.mock('/url', 'get', (req, res) => {  return Mock.mock({    status: 200,    req,    res,    data: '请求成功'  })})
// main.jsimport { createApp } from 'vue'import App from './App.vue'import axios from 'axios'import '../mock/index' // 引入mock路由拦截const vueApp = createApp(App)vueApp.config.globalProperties.$axios = axiosvueApp.mount('#app')

  7、修改helloWorld.vue文件如下:

// helloWorld.vue<template>  <div>    <button @click="getMockData">获取mock数据</button>  </div></template><script>export default {  name: 'HelloWorld',  methods: {    getMockData() {      this.$axios.get('/url').then(res => {        console.log(res)      })    }  }}</script><style scoped></style>

这时候页面效果如下:

vue-cli如何实现异步请求返回mock模拟数据

  到了这一步可以说是成功实现mock数据返回了,细心的朋友可能已经发现,network里面并没有出现请求,我们只能通过console查看返回结果,当请求数量多时就不太好调试了,那有没有什么办法可以让请求出现在network中呢?

  前面已经说到运行项目时,就是启动了一个本地服务器,只要想办法把接口路由配置进去就可以了,接着往下看

  9、修改vue.config.js中的devServer的配置,如果没有该文件则新建

// vue.config.jsconst Mock = require('mockjs')module.exports = {  //...  devServer: {    port: 8082,    before: function(app, server) { // webpack4使用before,webpack使用setupMiddlewares      app.get('/url', function(req, res) {        res.json(Mock.mock({          status: 200,          data: '请求成功啦~'        }));      });    }  }};

   注释main.js中引入的mock配置

import { createApp } from 'vue'import App from './App.vue'import axios from 'axios'// import '../mock/index' // 引入mock路由拦截const vueApp = createApp(App)vueApp.config.globalProperties.$axios = axiosvueApp.mount('#app')

  重启服务,重新点击按钮,成功请求,并且在network也出现了该请求,如下图

vue-cli如何实现异步请求返回mock模拟数据

  这样似乎已经实现了我们的目的了,既使用了mock模拟数据,也方便了调试,但是,在我们修改了返回的数据内容时,请求接口,发现还是原来的数据,因为是修改配置文件,所以每次修改都需要重启服务,这也太麻烦了吧,我们想每次修改before里的内容时,服务器都能够自动热更新,就像修改其他文件一样,浏览器自动更新,继续往下走。

  10、安装chokidar插件,监听mock文件夹,实现接口路由热更新,想了解更多chokidar的内容请自行搜索

> npm install chokidar -D

  11、在mock文件夹下新建mock-server.js,内容如下,就不具体细说了,大家可以自行调试

// mock/mock-server.jsconst chokidar = require('chokidar')const path = require('path')const mockDir = path.join(process.cwd(), 'mock')// 删除对应的接口路由缓存function removeRegisterRoutes() {  Object.keys(require.cache).forEach(i => {    if (i.includes(mockDir)) {      console.log(i)      delete require.cache[require.resolve(i)]    }  })}// 注册接口路由,每增加一个路由,app._router.stack就增加一个堆栈function registerRoutes(app){  const mocks = require('./index') // 这里必须在函数内引用,否则无法实现热更新  let count = 0  for (const mock of mocks) {    app[mock.method](mock.url, mock.response);    count++  }  return {    start: app._router.stack.length - count,    count  }}module.exports = (app) => {  let { start, count } = registerRoutes(app)  chokidar.watch(mockDir, {}).on('all', (event, path) => {    if (event === 'change' || event === 'add') {      app._router.stack.splice(start, count) // 先删除旧的api路由,再重新注册新的路由      removeRegisterRoutes()      const stack = registerRoutes(app)      start = stack.start      count = stack.count    }  })}

  注意,修改mock-server.js文件内容不会触发自动更新,具体原因这里就不说了,可以自己想一想哦~

  12、修改mock中的index.js文件

// mock/index.jsconst Mock = require('mockjs')const routers = [  {    url: '/url',    method: 'get',    response: (req, res) => {      res.json(Mock.mock({        status: 200,        data: '请求成功~'      }))    }  },  {    url: '/url/path',    method: 'get',    response: (req, res) => {      res.json(Mock.mock({        status: 200,        data: '请求接口/url/path'      }))    }  }]module.exports = routers

  13、修改vue.config.js的beforte

// vue.config.js// const Mock = require('mockjs')module.exports = {  //...  devServer: {    port: 8082,    before: require('./mock/mock-server')  }};

  重新启动,点击按钮,请求成功,修改mock中的index里面的返回数据,回到页面点击按钮,发现返回数据已改变,到此,已实现接口请求返回mock数据。

以上是“vue-cli如何实现异步请求返回mock模拟数据”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue-cli如何实现异步请求返回mock模拟数据

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue-cli如何实现异步请求返回mock模拟数据

这篇文章主要为大家展示了“vue-cli如何实现异步请求返回mock模拟数据”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue-cli如何实现异步请求返回mock模拟数据”这篇文章吧。  在前
2023-06-29

springBoot之如何获取接口请求数据和返回数据实现日志

这篇文章主要介绍了springBoot之如何获取接口请求数据和返回数据实现日志问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-14

大规模异步新闻爬虫中如何实现一个更好的网络请求函数

这篇文章将为大家详细讲解有关大规模异步新闻爬虫中如何实现一个更好的网络请求函数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。downloader 的实现import requestsimport ccha
2023-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录