在vue项目中使用mock模拟请求

在vue项目中使用mock模拟请求

一、为什么要使用mockjs

总结起来就是在后端接口没有开发完成之前,前端可以用已有的接口文档,在真实的请求上拦截ajax,并根据mockjs的mock数据的规则,模拟真实接口返回的数据,并将随机的模拟数据返回参与相应的数据交互处理,这样真正实现了前后台的分离开发。详细内容大家可以查阅mock文档:http://mockjs.com/0.1/#mock

二、在vue的项目中怎么去使用mockjs
1、搭建vue项目(不多说,直接用cli就可以);

这里不太清楚了的可以去看我总结的这篇文章,
vue2.0开发环境框架搭建

2、使用npm install mockjs --save-dev来安装mockjs;
(1)在src文件夹下创建mock文件夹,在该文件夹下创建mock.js。
import Mock from 'mockjs';

// 配置拦截 ajax 的请求时的行为,支持的配置项目有 timeout。
 Mock.setup({
    timeout: '200 - 400'
})

const vCode = '123456';

function getVerificatCode (prarms) {
    const prarmsObj = JSON.parse(prarms.body);
    return Object.assign(prarmsObj, {vCode: vCode});
}

function loginFun (prarms) {
    const prarmsObj = JSON.parse(prarms.body);
    if (prarmsObj.code === vCode) {
        return {code:1, text:'登录成功'}
    } else {
        return {code:2, text:'验证码有误,登录失败'}  
    }
}
const patients =[
	 {
	  id:'1',
	  title:'张大爷',
	  label:'男',
	  path:'/patient',
	  imgUrl:'../../static/images/20170622131955_h4eZS.thumb.700_0.jpeg'
	},
	{
	 id:'2',
	 title:'李大爷',
	 label:'男',
	 path:'/patient',
	 imgUrl:'../../static/images/20170622131955_h4eZS.thumb.700_0.jpeg'
	}]
// Mock.mock( url, post/get , 返回的数据);
Mock.mock('/getVerificatCode', 'post', getVerificatCode); // 获取验证码
Mock.mock('/login', 'post', loginFun); //登录
Mock.mock('/swipes',patients );
(2)在入口文件main.js里引入mockjs
import Vue from 'vue'
import App from './App'
import router from './router'
import axios from './http/api'

// 引入mockjs
require('./mock/mock.js')

Vue.config.productionTip = false
Vue.prototype.axios = axios
Vue.use(iView)

new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>'
})
(3)创建http文件夹,在该文件夹下创建api.js用来对axios做了拦截设置处理
let service = null;
service = axios.create({
    timeout: 30*1000,                   //请求超时时间
    baseURL: process.env.BASE_API,
    withCredentials: true,              //是否允许跨域
    cancelToken: source.token,
    headers: {
      'Content-Type': 'application/json;charset=UTF-8'
    }
})
 
// 请求拦截器
service .interceptors.request.use(config => {
    const token = localStorage.getItem('userToken');
    if (token) { // 判断是否存在token,如果存在的话,则每个http header都加上token
      config.headers.accessToken = token;
    }
    return config;
  }, 
  error => {
    return Promise.reject(error);
  })

// 响应拦截器
service .interceptors.response.use(response => {
    return response;
  },
  error => {
    return Promise.reject(error);
  })
 
export default service 
(4)最后在入口文件main.js里引入,将axios挂载到vue的原型上Vue.prototype.axios = axios。
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue项目,可以使用mock.js来模拟数据请求。引用\[1\]提到,mock.js可以在后端没有提供接口的情况下,自己模拟一个mock接口去请求,并且可以返回你希望得到的随机数据。这对于本地开发和演示项目非常有用。引用\[2\]提到,使用mock.js可以完全本地化实现数据,方便前端人员定义接口数据,并且可以配合后台人员进行开发。在Vue项目,可以通过引入mock.js并定义mock接口来模拟数据请求。例如,可以在一个mock文件夹创建一个mock.js文件,然后在该文件定义接口和返回的数据。在Vue组件,可以通过发送请求来获取mock数据。引用\[3\]给出了一个示例,展示了如何使用mock.js来请求获取.json文件的数据。在该示例,首先引入了mock-request工具和项目的设置文件,然后定义了一个tableData函数来发送请求并获取数据。这样,你就可以在Vue项目使用mock.js来模拟数据请求了。 #### 引用[.reference_title] - *1* [【Vue使用mock模拟数据](https://blog.csdn.net/ZHANGYANG_1109/article/details/124547442)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue本地模拟服务器请求mock数据](https://blog.csdn.net/liyoro/article/details/119616107)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值