最近在开发项目的时候,需要用到mockjs这个包来实现前端本地数据的模拟,下面我就来说一下具体步骤:
前言
uni-app将自己的配置融合到了vue.config.js中,所以需要自己配置,需要在package.json的同级目录下新建一个vue.config.js;ajax请求的路由,因为这个路由我们希望拿到模拟数据,所以用webpack的devserve来拦截。拦截之后通过mockjs,由它来生成模拟数据,然后返回模拟值。
步骤
在vue.config.js中加入下面代码:
const Mock = require('./mock/index.js');
module.exports = {
chainWebpack: (config) => {
config.resolve.alias
.set( '@',resolve(__dirname, '/'))//设置@为src目录的别名)
},
css: {
....
}
},
devServer: {
contentBase: path.join(__dirname, 'mock'),
compress: true,
port: 8080,
overlay: {
warnings: false,
errors: true
},
before(app){
Mock(app)
}
}
};
devserver的配置中的before配置项是拦截路由请求。我们把全部交给Mock(app)处理;然后打开mock/index.js写入如下代码:
const addressesMock = require('./addresses');
const attendanceMock = require('./attendance');
const attendanceListMock = require('./attendance-list');
....
function Mock(app) {
addressesMock(app)
attendanceMock(app)
attendanceListMock(app)
.....
}
module.exports = Mock;
打开addresses写入你需要mock的数据就ok啦
var Mockjs = require('mockjs')
const { Random }= Mockjs;
const phonePrefix = ['132', '135', '189']
const index = Math.floor(Math.random() * phonePrefix.length)
var phone = phonePrefix[index] + Mockjs.mock(/\d{8}/)
const addressesMock = function (app) {
app.get('/api3/addresses', function(req, res) {
var data = Mockjs.mock({
// 属性 list 的值是一个数组,其中元素的数量从 1 到 10 个都有可能,随机
'list|1-10': [{
'id|+1': 0,
"accept_name": Random.cname(),
"mobile": phone,
"province_name": Random.province(),
"area": Mockjs.mock(/\d{6}/),
"city": Mockjs.mock(/\d{6}/),
"sex": parseInt(Random.boolean()),
"district": {
"districts": Random.province()+Random.city()+Random.county(),
"area": Random.county(),
"city": Random.city(),
"province": Random.province()
},
"street": "有一间公寓八栋",
"inner": false,
"lat": "",
"door_number": "AB1234",
"is_default": parseInt(Random.boolean()),
"province": Mockjs.mock(/\d{6}/),
"area_name":Random.county(),
"city_name": Random.city(),
"poiname": ""
}]
})
res.json(data);
})
}
module.exports = addressesMock;
在需要接口的地方之间用 就能得到相应数据了
this.$ajax.get('/api3/addresses').then(res => { // 调用接口
})
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。