vue-cli如何实现异步请求返回mock模拟数据
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:
>npminstall-g@vue-cli
2、创建vue-cli项目:
>vuecreatevue-mock
创建成功后进入项目根目录,运行npm run serve启动,应该可以成功访问vue示例页面
本示例使用的版本是vue-cli 4.5.13、vue3、webpack4,如果发现某个配置不生效,请留意是否已经被废弃。
3、安装axios
>npminstallaxios-S
4、main.js添加aixos,修改如下
//main.jsimport{createApp}from'vue'importAppfrom'./App.vue'importaxiosfrom'axios'constvueApp=createApp(App)vueApp.config.globalProperties.$axios=axios//vue3与vue2的区别,不再是通过prototypevueApp.mount('#app')
5、安装mockjs
>npminstallmockjs-D
6、在根目录新建mock文件夹,在mock文件夹下新建index.js文件,并在main.js中引入index.js,代码如下:
//mock/index.jsimportMockfrom'mockjs'Mock.mock('/url','get',(req,res)=>{returnMock.mock({status:200,req,res,data:'请求成功'})})
//main.jsimport{createApp}from'vue'importAppfrom'./App.vue'importaxiosfrom'axios'import'../mock/index'//引入mock路由拦截constvueApp=createApp(App)vueApp.config.globalProperties.$axios=axiosvueApp.mount('#app')
7、修改helloWorld.vue文件如下:
//helloWorld.vue<template><div><button@click="getMockData">获取mock数据</button></div></template><script>exportdefault{name:'HelloWorld',methods:{getMockData(){this.$axios.get('/url').then(res=>{console.log(res)})}}}</script><stylescoped></style>
这时候页面效果如下:
到了这一步可以说是成功实现mock数据返回了,细心的朋友可能已经发现,network里面并没有出现请求,我们只能通过console查看返回结果,当请求数量多时就不太好调试了,那有没有什么办法可以让请求出现在network中呢?
前面已经说到运行项目时,就是启动了一个本地服务器,只要想办法把接口路由配置进去就可以了,接着往下看
9、修改vue.config.js中的devServer的配置,如果没有该文件则新建
//vue.config.jsconstMock=require('mockjs')module.exports={//...devServer:{port:8082,before:function(app,server){//webpack4使用before,webpack使用setupMiddlewaresapp.get('/url',function(req,res){res.json(Mock.mock({status:200,data:'请求成功啦~'}));});}}};
注释main.js中引入的mock配置
import{createApp}from'vue'importAppfrom'./App.vue'importaxiosfrom'axios'//import'../mock/index'//引入mock路由拦截constvueApp=createApp(App)vueApp.config.globalProperties.$axios=axiosvueApp.mount('#app')
重启服务,重新点击按钮,成功请求,并且在network也出现了该请求,如下图
这样似乎已经实现了我们的目的了,既使用了mock模拟数据,也方便了调试,但是,在我们修改了返回的数据内容时,请求接口,发现还是原来的数据,因为是修改配置文件,所以每次修改都需要重启服务,这也太麻烦了吧,我们想每次修改before里的内容时,服务器都能够自动热更新,就像修改其他文件一样,浏览器自动更新,继续往下走。
10、安装chokidar插件,监听mock文件夹,实现接口路由热更新,想了解更多chokidar的内容请自行搜索
>npminstallchokidar-D
11、在mock文件夹下新建mock-server.js,内容如下,就不具体细说了,大家可以自行调试
//mock/mock-server.jsconstchokidar=require('chokidar')constpath=require('path')constmockDir=path.join(process.cwd(),'mock')//删除对应的接口路由缓存functionremoveRegisterRoutes(){Object.keys(require.cache).forEach(i=>{if(i.includes(mockDir)){console.log(i)deleterequire.cache[require.resolve(i)]}})}//注册接口路由,每增加一个路由,app._router.stack就增加一个堆栈functionregisterRoutes(app){constmocks=require('./index')//这里必须在函数内引用,否则无法实现热更新letcount=0for(constmockofmocks){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()conststack=registerRoutes(app)start=stack.startcount=stack.count}})}
注意,修改mock-server.js文件内容不会触发自动更新,具体原因这里就不说了,可以自己想一想哦~
12、修改mock中的index.js文件
//mock/index.jsconstMock=require('mockjs')constrouters=[{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//constMock=require('mockjs')module.exports={//...devServer:{port:8082,before:require('./mock/mock-server')}};
重新启动,点击按钮,请求成功,修改mock中的index里面的返回数据,回到页面点击按钮,发现返回数据已改变,到此,已实现接口请求返回mock数据。
以上是“vue-cli如何实现异步请求返回mock模拟数据”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注恰卡编程网行业资讯频道!
推荐阅读
-
将mock模拟数据插入到Mysql数据库
-
vue本地模拟服务器怎么请求mock数据
-
vue-cli项目中怎么配置反向代理
-
如何在vue-cli中引入jQuery,Bootstrap和popper
如何在vue-cli中引入jQuery,Bootstrap和popper?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小...
-
怎么在vue-cli webpack中引入swiper
怎么在vue-cliwebpack中引入swiper?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解...
-
如何安装与使用vue-cli脚手架
-
怎么使用Vue-cli 3.0搭建Vue项目
-
怎么在vue-cli搭建的项目中增加后台mock接口