介绍
mockjs是用于拦截ajax请求,模拟服务器返回数据
mockjs的实现原理是对XHR对象的拦截,属于js拦截,所以浏览器并没有发出请求
基本使用
安装 npm install mockjs --save
src目录下新建mock目录 并新建mock.js src/mock/mock.js
mock.js中:
import Mock from 'mockjs';
Mock.mock('url',{
// 返回的数据
});
Mock.mock('url','请求方式get/post',{
// 返回对象
)
Mock.mock('url','请求方式',function(requestObj){
// 根据请求参数返回数据
});
最后将mockjs 在入口文件main.js 中引入
main.js:
import './mock/mock.js'
拦截带参数的get请求
mockjs默认只拦截不带参数的get请求和post请求
因为post请求的参数是放在请求体中,get请求的参数是拼接在url地址后,
所以mockjs 默认不能拦截带参数的get请求
若需要拦截带参数的get请求,需要使用正则判断一下url地址
//拦截带参数的get请求
Mock.mock(RegExp('url'+'.*'),'get',function(requestObj){
requestObj为请求对象 get请求的参数需要从url中分解
})
根据当前环境设置是否使用mockjs
根据环境 设置开发环境使用mock 生产环境不使用mock
在main.js中 根据proces.env判断是否引入mock
process.env.NODE_ENV!='production'&&import './mock/mock.js';
process是nodejs全局对象
process.env可全局来判断当前开发环境or生产环境
解决mock拦截数据 浏览器不发请求问题
mockjs的实现原理是拦截XHR对象,属于js拦截,所以浏览器并没有发出请求,
这常常导致无法在谷歌调试工具中查看请求参数等,为了解决这样的问题,可以使用easy-mock
easy-mock 集成了mockjs和mock server
登录easy-mock官网、创建项目,就可以基于创建的项目创建一些接口
会生成类似
```https://www.easy-mock.com/mock/~~~```的完整接口地址
因为easy-mock继承了mockjs 所以生成接口返回数据时候也可以使用mockjs的模板来创建数据,可更快捷
此时既可以正常请求接口 又可以返回模拟的数据