mock.js +axios +vue 简单模拟后台接口

mock 生成随机数,拦截ajax请求
axios 官方文档

npm安装

npm install mockjs //安装mock
npm install axios //安装axios

mock 构造数据规则

语法规范
Mock.js 的语法规范包括两部分:

  1. 数据模板定义规范(Data Template Definition,DTD)
  2. 数据占位符定义规范(Data Placeholder Definition,DPD)

数据模板定义规范 DTD

数据模板中的每个属性由 3 部分构成:属性名、生成规则、属性值:

// 属性名   name
// 生成规则 rule
// 属性值   value
'name|rule': value

注意:

  • 属性名生成规则 之间用竖线 | 分隔。
  • 生成规则 是可选的。
  • 生成规则 有 7 种格式:
    1. 'name|min-max': value
    2. 'name|count': value
    3. 'name|min-max.dmin-dmax': value
    4. 'name|min-max.dcount': value
    5. 'name|count.dmin-dmax': value
    6. 'name|count.dcount': value
    7. 'name|+step': value
  • 生成规则 的 含义 需要依赖 属性值的类型 才能确定。
  • 属性值 中可以含有 @占位符
  • 属性值 还指定了最终值的初始值和类型

mock.js常用 api

Mock.mock()
Mock.mock(url, type, data) 根据数据模板生成模拟数据
url URL 字符串或 URL 正则 拦截请求的地址
type 拦截Axios类型 GET、POST
template 可以是对象或字符串 生成数据的模板

控制台验证 Mock代码示例

mock 示例代码

1111.png

var Mock = require('mockjs')
var data = Mock.mock({
    // 属性 list 的值是一个数组,其中含有 1 到 10 个元素
    'list|1-10': [{
        // 属性 id 是一个自增数,起始值为 1,每次增 1
        'id|+1': 1
    }]
})
// 输出结果
console.log(JSON.stringify(data, null, 4))

测试项目实例

目录结构

3330808.png

mock-user.js

export const mockUser = {
    login: {
      api: '/api/mock/getUserInfo',
      method: 'post',
      enabled: true,
      data:{
        userName:'hello shadow',
        nickName:'我是mock返回数据!!'
      }
    }
  }

mock.js

import {mockUser} from './mock-user'

const mockList = [
  mockUser,
  // 在这个列表下面添加对应的
]
// -----这里可以添加其他mock请求配置------
const apiMockConfig = {
  mocks:[],
  mockEnabled:function(path){
    var result = false;
    this.mocks.forEach(item=>{
      if (item.api == path) {
        result = item.enabled;
      }
    });
    return result;
  }
};
mockList.forEach(configs=>{
  Object.keys(configs).forEach(key=>{
    apiMockConfig.mocks.push(configs[key]);
  });
});
export default apiMockConfig;

api.js

import apiMockConfig from './mock/mock'
const axios = require('axios');
const baseUrl = "http://192.168.2.176:12306";
const Mock = require('mockjs');
    apiMockConfig.mocks.forEach(config=>{
        if  (config.enabled) {
            Mock.mock(baseUrl + config.api,config.method, ()=>{
                return {
                    msg: 'ok',
                    code: '0',
                    success: true,
                    data: config.data
                }
            });
        }
    });
    

    function createAxios(type){
        let timeout = 20000; //统一的超时时间
        var token = "123456789";
     
        let applicationHeaderPayload = {
            'Content-Type': 'application/json; charset=utf-8',
            'token':token,
            'Accept': '*/*'
        }
        let applicationHeader = {
            'Content-Type': 'application/x-www-form-urlencoded', 
            'token':token,
            'Accept': '*/*'
        }; 
        let args = {}; //配置参数
        let axiosInstance; //请求实力
        switch(type){
            case "payload" :
                args = {
                    timeout,
                    "headers": applicationHeaderPayload
                };
                break;
            case "formData" :
                args = {
                    timeout,
                    "headers" : applicationHeader
                };
                break;
            default :
                break;
        }
        axiosInstance = axios.create(args);

        axiosInstance.interceptors.request.use (function (config) { //请求拦截器
            console.log("baseUrl+config.url = "+baseUrl+config.url)
            config.url = baseUrl+config.url;
            return config;
        }, function (error) {
            console.log("request error")
            return Promise.reject(error);
        });

        axiosInstance.interceptors.response.use(function (response) { //返回拦截器
            console.log("response---"+JSON.stringify(response))
            return handleSuccess(response);
        }, function (data) {
            console.log("response error--"+data)
            return handleError(data);
        });
        return axiosInstance;
    }

    function handleSuccess(response){ //处理正常返回
       
        let code = response.data.code;
        console.log("handleSuccess code ---"+code)
        if(code == 0){
            return Promise.resolve(response.data);
        }else{
            return Promise.reject(response);
        }
    }
    function handleError(response){ //处理失败返回
        if (response && response.response && response.response.status==401) { 
            return Promise.reject(response);
        }
        console.error("handleError--"+response);
        return Promise.reject(response);
    }
    
    //payload块
    const payload = createAxios("payload");
    //formdata块
    const formdata = createAxios("formData");
    
    const getUserInfo = () => {
        return payload.post("/api/mock/getUserInfo");
    }
    
    //todo 请求参数
    export default {
        payload,
        formdata,
        getUserInfo,
    }

vue获取接口数据

import api from "./api/apis"
  mockTest() {
        console.log("hello,mock测试")
        api.getUserInfo().then((res) => {
          console.log("获取成功---" + JSON.stringify(res))
          this.userInfo = res.data
        }).catch((e) => {
          console.log("获取失败---" + JSON.stringify(e))
        })
      }

返回数据

获取成功---{"msg":"ok","code":"0","success":true,"data":{"userName":"hello shadow","nickName":"我是mock返回数据!!"}}
22220.png

示例项目地址

webDemo

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容

  • Mock 安装 生成随机数据,模拟ajax请求 # 安装 npm install mockjs # 引用 impo...
    把我当做一棵树叭阅读 1,271评论 0 1
  • 在开发过程中,有很多的ajax请求,前后端分离开发你肯定遇到这样的问题,后台给你的接口文档,你需要在本地模拟数据返...
    清汤饺子阅读 120,508评论 6 77
  • 前端开发过程中免不了出现等接口的情况,而静态 JSON 不足以体现前端高大上的逼格,是时候拿出 mock.js 了...
    MrWelson阅读 1,771评论 0 0
  • 创建 1、在vue项目的根目录下创建mock文件。 2、下载依赖 npm install mockjs --sav...
    时间__前端阅读 701评论 0 2
  • 什么是mock.js 在前后端分离的开发环境中,前端同学需要等待后端同学给出接口及接口文档之后,才能继续开发。而M...
    岁月神偷___阅读 574评论 0 3