欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用Mock.js生成前端测试数据

程序员文章站 2022-03-22 15:37:05
mock.js是一个模拟数据生成器,可以让前端独立于后端进行开发。如果你正在开发一个前端页面,可是后台还没有完成供你调用的api,并且数据格式已经确定,那么你就可以使用mock.js模拟相关的接口,生...

mock.js是一个模拟数据生成器,可以让前端独立于后端进行开发。如果你正在开发一个前端页面,可是后台还没有完成供你调用的api,并且数据格式已经确定,那么你就可以使用mock.js模拟相关的接口,生成假数据来查看页面效果。mock.js的功能:生成随机数据,拦截 ajax 请求。

参考文档:https://github.com/nuysoft/mock/wiki/getting-started

语法规范:https://github.com/nuysoft/mock/wiki/syntax-specification

安装

npm install mockjs

创建模拟api,拦截ajax请求,返回测试数据

  //模拟后台
  mock.mock('http://api.com', {
    "user|5-10": [{
      'name': '@cname',  //中文名称
      'age|1-100': 100,  //100以内随机整数
      'birthday': '@date("yyyy-mm-dd")', //日期
      'city': '@city(true)'  //中国城市
    }]
  });

发送ajax请求

  //jquery方式
  $.ajax({
    url: 'http://api.com',
    datatype: 'json'
  }).done(function(data, status, xhr) {
    console.log(
      json.stringify(data, null, 4)
    )
  });
  //原生ajax方式
  function myajax(url) {
      if (window.xmlhttprequest) {
        ajax = new xmlhttprequest();
      } else if (window.activexobject) {
        try {
          ajax = new activexobject("msxml2.xmlhttp");
        } catch (e) {
          try {
            ajax = new activexobject("microsoft.xmlhttp");
          } catch (e) {}
        }
      }
      if (!ajax) {
        window.alert("不能创建xmlhttprequest对象实例.");
        return false;
      }
      ajax.open("get", url, true);
      ajax.send(null);
      ajax.onreadystatechange = function() {
        if (ajax.readystate == 4 && ajax.status == 200) {
          console.log(ajax.responsetext);
        }
      }
    }

  myajax('http://api.com');

查看响应

{
  "user": [
    {
      "name": "锺丽",
      "age": 17,
      "birthday": "1983-11-01",
      "city": "内蒙古自治区 赤峰市"
    },
    {
      "name": "陈艳",
      "age": 25,
      "birthday": "1973-07-10",
      "city": "河南省 驻马店市"
    },
    {
      "name": "冯霞",
      "age": 59,
      "birthday": "2010-10-28",
      "city": "澳门特别行政区 离岛"
    },
    {
      "name": "贾秀英",
      "age": 63,
      "birthday": "1973-01-22",
      "city": "**自治区 伊犁哈萨克自治州"
    },
    {
      "name": "周勇",
      "age": 34,
      "birthday": "1985-05-21",
      "city": "湖南省 衡阳市"
    }
  ]
}

示例

// 使用 mock
var mock = require('mockjs')

/**
 * 
 * 数据模板
 * 属性名|生成规则: 属性值
 */
var data = mock.mock({
  // 属性 list 的值是一个数组,其中含有 1 到 10 个元素
  'list|1-10': [{
    // 属性 id 是一个自增数,起始值为 1,每次增 1
    'id|+1': 1,
    'name': '@first'
  }]
})

// 输出结果
console.log(json.stringify(data, null, 4))

运行结果

{
    "list": [
        {
            "id": 1,
            "name": "larry"
        },
        {
            "id": 2,
            "name": "edward"
        },
        {
            "id": 3,
            "name": "jessica"
        },
        {
            "id": 4,
            "name": "william"
        },
        {
            "id": 5,
            "name": "christopher"
        },
        {
            "id": 6,
            "name": "michael"
        },
        {
            "id": 7,
            "name": "susan"
        },
        {
            "id": 8,
            "name": "shirley"
        },
        {
            "id": 9,
            "name": "angela"
        },
        {
            "id": 10,
            "name": "george"
        }
    ]
}

到此这篇关于使用mock.js生成前端测试数据的文章就介绍到这了,更多相关mock.js生成测试数据内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!