本文主要给大家介绍了关于利用vue + koa2 + mockjs模拟数据的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
关于mockjs,官网描述的是
1.前后端分离
2.不需要修改既有代码,就可以拦截 ajax 请求,返回模拟的响应数据。
3.数据类型丰富
4.通过随机数据,模拟各种场景。
等等优点。
第一步 安装vue-cli项目 不多说网上一大把
需要的朋友们参考这篇文章:http://www.jb51.net/article/118987.htm ,介绍的非常详细。
第二步 因为本地的vue访问本地的mock
1、配置vue代理
在config/index.js里面的proxytable,因为本地node启动的服务默认访问的是3000端口
所以在target里面配置http://localhost:3000/
proxytable: {
'/api': {
target: 'http://localhost:3000/',
changeorigin: true,
pathrewrite: {
'^/api': '/'
}
}
2、在vue项目的mianjs中
import axios from 'axios'
axios.defaults.baseurl = '/api'
第三步 搭建nodejs的koa2项目
全局安装koa,不是koa2注意
1、npm install -g koa-generator
创建文件夹下面hellokoa2是你的项目名字
2、koa2 hellokoa2
进入该文件夹然后执行安装依赖
3、cd hellokoa2然后npm install
上面完成了nodejs的初始化接着操作
4、继续安装依赖文件
npm install mockjs --save -dev //mock文件
npm install koa2-cors --save -dev //node端配置cors支持跨域用
5、配置app.js文件 注意下面注释的新增部分就是在本来app.js文件上面新增的东西
const koa = require('koa')
const app = new koa()
const views = require('koa-views')
const json = require('koa-json')
const onerror = require('koa-onerror')
const bodyparser = require('koa-bodyparser')
const logger = require('koa-logger')
const cors = require('koa2-cors') // 新增部分处理跨域
//这里提一点题外话 假如routes文件新增一个路径就的在下面增加路劲
//假设routes新增一个user.js
//新增一个user需要修改两个地方这里是一个 下面还有一个地方
//这里需要 const user = require('./routes/user')
const index = require('./routes/index')
const users = require('./routes/users')
// error handler
onerror(app)
// middlewares
app.use(bodyparser({
enabletypes:['json', 'form', 'text']
}))
app.use(cors()) // 新增部分处理跨域
app.use(json())
app.use(logger())
app.use(require('koa-static')(__dirname + '/public'))
app.use(views(__dirname + '/views', {
extension: 'pug'
}))
// logger
app.use(async (ctx, next) => {
const start = new date()
await next()
const ms = new date() - start
console.log(`${ctx.method} ${ctx.url} - ${ms}ms`)
})
//这里提一点题外话 假如routes文件新增一个路径就的在下面增加路劲
//假设routes新增一个user.js
//这里需要 app.use(user.routes(), user.allowedmethods())
app.use(index.routes(), index.allowedmethods())
app.use(users.routes(), users.allowedmethods())
// error-handling
app.on('error', (err, ctx) => {
console.error('server error', err, ctx)
});
module.exports = app
6、正式使用mock 我这里直接在routes/index.js里面使用
routes/index.js文件如下
const router = require('koa-router')()
var mock = require('mockjs') //引入mockjs
const random = mock.random; //引入mockjs生成随机属性的函数 random具体可以生成
//哪些东西详见http://mockjs.com/examples.html
router.prefix('/index')
router.get('/string', async (ctx, next) => {
//116到125 是mock的第一种使用方法,这种方法随机生成1到10个数组但是每个数组的author、title等都一样
// ctx.body = await mock.mock({
// // 属性 list 的值是一个数组,其中含有 1 到 10 个元素
// 'arr|1-10': [{
// // 属性 id 是一个自增数,起始值为 1,每次增 1
// 'id|+1': 1,
// 'author|+1': random.cname(),
// 'img': random.image('100x100'),
// 'title':random.csentence(5, 9)
// }]
// })
//127到141是mock的第二种方法主要使用random函数来生成 这里生成的title、author等每个都不一样
const producenewsdata = function() {
let articles = [];
for (let i = 0; i < 50; i++) {
let newarticleobject = {
title: random.csentence(5, 30), // random.csentence( min, max )
author: random.cname(), // random.cname() 随机生成一个常见的中文姓名
}
articles.push(newarticleobject)
}
return {
articles: articles
}
}
ctx.body = await producenewsdata()
})
这里提一点 http://mockjs.com/examples.html 官网 看清楚每种数据的用法
7、启动node
npm run dev
相关推荐:
php模拟数据库常用操作效果
利用mysql日志模拟数据变化轨迹
php模拟数据库常用操作效果
以上就是利用vue 、 koa2 、mockjs模拟数据详解的详细内容。