这篇文章主要为大家详细介绍了分析vue-cli 本地开发mock数据使用方法,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
vue-cli 中可以通过配置 proxyTable 解决开发环境的跨域问题,具体可以参考这篇文章:Vue-cli proxyTable 解决开发环境的跨域问题
如果后端接口尚未开发完成,前端开发一般使用mock数据。
mock方法有多种多样,这里给出两种:
mock数据写在json文件中,proxyTable 里将接口代理到具体mock数据json文件上。
具体方法:
创建 mock
文件夹
build/dev-server.js
中添加如下代码
【图片暂缺】
npm run dev 启动后,可以通过 http://localhost:8080/mock/db.json 访问数据,proxyTable对应设置代理即可(代理设置方法与解决跨域方法相似)
【图片暂缺】
JSON Server 是一个创建伪RESTful服务器的工具,具体使用方法可以看官方文档,这里直接讲在vue-cli 中的用法。
全局安装 $ npm install -g json-server
项目目录下创建 mock
文件夹
mock
文件夹下添加 db.json
文件,内容如下
代码如下:
{
"posts": [
{ "id": 1, "title": "json-server", "author": "typicode" }
],
"comments": [
{ "id": 1, "body": "some comment", "postId": 1 }
],
"profile": { "name": "typicode" }
}
package.json
添加命令
代码如下:
"mock": "json-server --watch mock/db.json",
"mockdev": "npm run mock & npm run dev"
【图片暂缺】
$ npm run mock
命令 运行 mock server
访问 http://localhost:3000/
发现 db.json
下第一级 json 对象被解析成为可访问路径
【图片暂缺】
GET请求具体路径 如:http://localhost:3000/posts 可获取数据
【图片暂缺】
如果需要大量的伪数据,手动构造比较费时费力,可以使用faker.js 批量生成。faker.js 的具体使用参见官方文档,这里做一个示例。
$ cnpm install faker -G
全局安装 faker
mock
目录下创建 faker-data.js
,内容如下
代码如下:
module.exports = function () {
var faker = require("faker");
faker.locale = "zh_CN";
var _ = require("lodash");
return {
people: _.times(100, function (n) {
return {
id: n,
name: faker.name.findName(),
avatar: faker.internet.avatar()
}
}),
address: _.times(100, function (n) {
return {
id: faker.random.uuid(),
city: faker.address.city(),
county: faker.address.county()
}
})
}
}
$ json-server mock/faker-data.js
在 json server 中使用 faker
请求 http://localhost:3000/address 可以获取到随机生成的100组伪数据
【图片暂缺】
json server 使用 RESTful 架构,GET请求可以获取数据,POST 请求则是添加数据。
在开发过程中,有时候想直接模拟获取POST请求返回结果,可以添加 express 中间件 将POST请求转为GET请求。
mock
目录下创建 post-to-get.js
,内容如下
代码如下:
module.exports = function (req, res, next) {
req.method = "GET";
next();
}
启动命令添加运行中间件 --m mock/post-to-get.js
代码如下:
"mock": "json-server --watch mock/db.json --m mock/post-to-get.js",
重新启动服务,POST请求就被转换为GET请求了
【图片暂缺】
其他需求也可以通过添加不同的中间件实现。
在 config/index.js
的 proxyTable
将请求映射到 http://localhost:3000
【图片暂缺】
代码中添加请求以测试效果
【图片暂缺】
$ npm run mockdev
启动带mock 数据的本地服务
结果如下:
【图片暂缺】
整体代码:https://github.com/carrotz/vue-cli-mock
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持四海网。
本文来自:http://www.q1010.com/184/5487-0.html
注:关于分析vue-cli 本地开发mock数据使用方法的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。
关键词:vue.js
四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。