vue-cli项目如何利用mock 模拟数据

   第一步:在项目中安装mockjs、axios(http请求库)

         cnpm install mockjs axios --save

第二步:
在项目中新建一个mock.js文件,用于定义接口返回的数据 内容如下:
const Mock = require('mockjs') // 获取mock对象 const Random = Mock.Random // 获取random对象,随机生成各种数据,具体请翻阅文档 const domain = 'http://mockjs.com/api' // 定义默认域名,随便写 const code = 200 // 返回的状态码 // 随机生成文章数据 const postData = req => { console.log(req) // 请求体,用于获取参数 let posts = [] // 用于存放文章数据的数组 for (let i = 0; i < 10; i++) { let post = { title: Random.csentence(10, 25), // 随机生成长度为10-25的标题 icon: Random.dataImage('250x250', '文章icon'), // 随机生成大小为250x250的图片链接 author: Random.cname(), // 随机生成名字 date: Random.date() + ' ' + Random.time() // 随机生成年月日 + 时间 } posts.push(post) } // 返回状态码和文章数据posts return { code, posts } } // 定义请求链接,类型,还有返回数据 Mock.mock(`${domain}/posts`, 'get', postData);

第三步:在main.js中引入
import Mock from './mock' // 刚刚手写的mock.js文件 import axios from 'axios' // axios http请求库 axios.defaults.baseURL = 'http://mockjs.com/api' // 设置默认请求的url Vue.prototype.$http = axios
第四部:在组建中调接口请求数据
  
this.$http.get("/posts").then(res => { console.log(res); });

注意:这种方式调用到的数据可以在console中打印出来,但是并不能够在network中看到接口。
如果你想通过这一个文件模拟几个接口的数据,可以自己创建下图中的代码体,改变红框部分,和里面你所需要模拟的数据,具体见mock.js官网。

最后,一定要把这个加上


希望对您有点帮助哟!
 








猜你喜欢

转载自www.cnblogs.com/bbldhf/p/11070782.html