vue+mockjs模拟数据以及list分页功能
vue+mockjs模拟数据以及list分页功能
0.1442019.06.01 10:30:30字数 132阅读 2,317
第一步:安装mockjs
npm install mockjs --save-dev
第二步:创建 mock.js 文件
//mock.js 文件
import Mock from mockjs // 引入mockjs
const Random = Mock.Random // Mock.Random 是一个工具类,用于生成各种随机数据
const dataList = [] // 用于接受生成数据的数组
for (let i = 0; i < 26; i++) { // 可自定义生成的个数
const template = {
Boolean: Random.boolean, // 可以生成基本数据类型
Natural: Random.natural(1, 10), // 生成1到100之间自然数
Integer: Random.integer(1, 100), // 生成1到100之间的整数
Float: Random.float(0, 100, 0, 5), // 生成0到100之间的浮点数,小数点后尾数为0到5位
Character: Random.character(), // 生成随机字符串,可加参数定义规则
String: Random.string(2, 10), // 生成2到10个字符之间的字符串
Range: Random.range(0, 10, 2), // 生成一个随机数组
Date: Random.date(), // 生成一个随机日期,可加参数定义日期格式
Image: Random.image(Random.size, #02adea, Hello), // Random.size表示将从size数据中任选一个数据
Color: Random.color(), // 生成一个颜色随机值
Paragraph: Random.paragraph(2, 5), // 生成2至5个句子的文本
Name: Random.name(), // 生成姓名
Url: Random.url(), // 生成web地址
Address: Random.province() // 生成地址
}
dataList.push(template)
}
// list 分页接口()
Mock.mock(http://localhost:8080/api/list, post, (params) => {
var info = JSON.parse(params.body)
var [index, size, total] = [info.pageIndex, info.pageSize, dataList.length]
var len = total / size
var totalPages = len - parseInt(len) > 0 ? parseInt(len) + 1 : len
var newDataList = dataList.slice(index * size, (index + 1) * size)
return {
code: 0,
message: success,
data: {
pageIndex: index,
pageSize: size,
rows: newDataList,
total: total,
totalPages: totalPages
}
}
})
第三步:main.js 文件引入mock.js 文件 (或者引入你需要的某个文件中也可以)
require(./utils/mock.js)
第四步:使用
listParams = {
pageIndex: 0,
pageSize: 10
}
async getList() {
const result = await ajax.post([http://localhost:8080/api/list], JSON.stringify(this.listParams));
if (result.code === 0) {
this.tableData = result.data.rows
this.initPager.total = result.data.total
}
}
*注意:1、如果开发中有用后台的域名, mockjs中定义接口加上本地的主机名,不然会有跨域的问题
上一篇:
IDEA上Java项目控制台中文乱码
