基础知识-Mockjs进行数据模拟
1. 目标
目标: 模拟正常的 Ajax 数据。
目标分解:
- 创建 nodejs + express 服务器,安装 supervisor 热更新插件。
- 安装 mockjs, 熟悉 mockjs 语法。
- 设置代理,解决 vue 项目跨域问题。
- 设置响应头,解决无法获取获取 token 和 cookie 问题。
2. 创建模拟数据服务器
安装 express
// 安装express生成器
npm install -g express-generator
// 创建express项目
express [name]
npm i
// 实现数据热更新
npm install -S supervisor
// 启动服务
supervisor ./bin/www
创建一个简单的的 api , 打开文件 /routes/index.js , 修改代码
router.get('/api/temp', function(req, res, next) {
var data = {
hello: "hello word"
}
// 返回数据
res.send(JSON.stringify(data));
});
// 地址: localhost:3000/api/temp
// 结果: {"hello": "hello word"}
3. 安装 mockjs, 熟悉 mockjs 语法
安装 mockjs:
npm install mockjs -S
使用 mockjs, 模拟数据。
打开 /routes/index.js
var Mock = require('mockjs');
var Random = Mock.Random;
router.get('/api/temp', function(req, res, next) {
// mockjs 模拟数据
var data = Mock.mock({
"string|1-10": "★"
})
// 返回数据
res.send(JSON.stringify(data, null, 4));
});
// 地址: localhost:3000/api/temp
// 结果: {"string": "★★★★★★"}
参考文档:
- http://mockjs.com/0.1/#
- http://mockjs.com/examples.html#Basic
- 数据在线模拟:http://mockjs.com/0.1/editor.html#help
4. 设置代理,解决 vue 项目跨域问题
用 axios 过程中,会发现获取的数据已经接收到,但无法获取。控制台提示跨域问题。
在 vue 项目中,可以用 代理解决跨域问题。
创建一个 vue3.0 项目。
创建一个 axios 请求。
// html
<el-button @click='show'>el-button</el-button> // js
methods: {
show: function() {
console.log('打印数据')
this.$axios.get('/api')
.then(function(response) {
console.log(response);
})
.catch(function(error) {
console.log(error);
});
}
},
创建 开发、生产、测试开发环境 配置。
3.1. 创建
/config/文件夹下三个文件:dev.env.jspro.env.jsuat.env.jsconst hosturl= 'http://127.0.0.1:3000';
// 开发环境
module.exports = {
NODE_ENV: '"development"',
hosturl:hosturl
}
// 生产环境
module.exports = {
NODE_ENV: '"production"',
hosturl:''
}
// 测试环境
module.exports = {
NODE_ENV: '"test"',
hosturl:''
}
配置 vue.config.js 和 package.json 文件,创建代理
var path = require('path'); const devProxy = ['/api']; // 代理
// const devProxy = ['/pc','/weixin','android',...]; // 代理
var proEnv = require('./config/pro.env'); // 生产环境
var uatEnv = require('./config/uat.env'); // 测试环境
var devEnv = require('./config/dev.env'); // 开发环境
const env = process.env.NODE_ENV;
let target = ''; // 默认是本地环境
if(env==='production'){ // 生产环境
target = proEnv.hosturl;
}else if(env==='test'){ // 测试环境
target = uatEnv.hosturl;
}else{ // 开发环境
target = devEnv.hosturl;
} // 生成代理配置对象
let proxyObj = {};
devProxy.forEach((value, index) => {
proxyObj[value] = {
// wx: false, // 某些情况会报错,可以将其设置为 false
target: target,
changeOrigin: true,
pathRewrite: {
[`^${value}`]: value
}
};
}); module.exports = {
lintOnSave: false, // 关闭eslint的检查功能
publicPath: './', // 原来的 base_url 已废弃,改用这个属性
outputDir: 'dist',
devServer: {
host: '0.0.0.0',
port: 8080,
https: false,
hotOnly: false,
disableHostCheck: true,
proxy: proxyObj, // string | Object
}
};
"scripts": {
"dev": "vue-cli-service serve --open",
"prod":"vue-cli-service build --mode=production",
"test": "vue-cli-service build --mode=test"
}运行代码:
npm run dev// 打印结果:
> 打印数据
> {data: {…}, status: 200, statusText: "OK", headers: {…}, config: {…}, …}
5. 设置响应头,解决无法获取获取 token 和 cookie 问题
token 问题:
在本例子中可以成功获取 token 属性,为了防止出现意外的情况获取不到token,在这里将讲解 token 获取问题。
// 解决无法获取响应头 token 问题。
// 修改 app.js 文件,下面代码放在路由组件注册前。
// 路由组件 app.use('/', indexRouter);
app.all('*', function(req, res, next) {
res.setHeader('Access-Control-Expose-Headers', 'token'); //多个属性可用,分开
next();
});
cookie 问题:
小伙伴们应该会发现一个问题, 用 axios 打印数据, 无法获取响应体携带的 cookie 属性。
这是由于由于浏览器的保护机制,具体百度 httponly。
6. 为什么用 Express 来搭建数据模拟服务
用 Express 主要原因,是为了对获取到的请求数据进行判断,能对请求参数进行处理,返回不同的响应数据。
具体如何如何操作数据,请阅读 Express 中间件参考文档。
参考地址:http://www.expressjs.com.cn/4x/api.html#req
错误修改:
- vue-cli 3.0 配置文件
vue.config.js修改已废弃配置。 vue.config.js修改wx: false属性,解决一些错误。
如有错误, 请留言区反馈, 谢谢.
基础知识-Mockjs进行数据模拟的更多相关文章
- SpringMVC(一) 基础知识+入门案例
SpringMVC基础知识 1.什么是Springmvc 2.springmvc 框架的原理(必须掌握) 前端控制器.处理器映射器.处理器适配器.视图解析器 3.SpringMVC 入门程序 目的:对 ...
- .NET面试题系列[1] - .NET框架基础知识(1)
很明显,CLS是CTS的一个子集,而且是最小的子集. - 张子阳 .NET框架基础知识(1) 参考资料: http://www.tracefact.net/CLR-and-Framework/DotN ...
- RabbitMQ基础知识
RabbitMQ基础知识 一.背景 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然 ...
- Java基础知识(壹)
写在前面的话 这篇博客,是很早之前自己的学习Java基础知识的,所记录的内容,仅仅是当时学习的一个总结随笔.现在分享出来,希望能帮助大家,如有不足的,希望大家支出. 后续会继续分享基础知识手记.希望能 ...
- selenium自动化基础知识
什么是自动化测试? 自动化测试分为:功能自动化和性能自动化 功能自动化即使用计算机通过编码的方式来替代手工测试,完成一些重复性比较高的测试,解放测试人员的测试压力.同时,如果系统有不份模块更改后,只要 ...
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
随机推荐
- x86汇编语言实践(1)
0 写在前面 为了更深入的了解程序的实现原理,近期我学习了IBM-PC相关原理,并手工编写了一些x86汇编程序. 在2017年的计算机组成原理中,曾对MIPS体系结构及其汇编语言有过一定的了解,考虑到 ...
- nginx服务器的基本配置
nginx作为反向代理搭建服务器的优点. 处理响应请求很快:单次请求会得到更快的响应.在高峰期,Nginx 可以比其它的 Web 服务器更快的响应请求 高并发连接:理论上,Nginx 支持的并发连接上 ...
- Aerospike-内存和硬盘混合存储的kv数据库
为什么会有Aerospike? Redis是一个纯内存型数据库,性能上没有多大问题. 但这又带来一个新问题,内存是很贵的,所以全内存的存储成本非常昂贵.为了节省成本,我们需要把一部分不经常用到的数据存 ...
- Java实现AES加密
一)什么是AES? 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),是一种区块加密标准.这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用. ...
- ZooKeeper-配置 zoo.cfg
官方说明:https://zookeeper.apache.org/doc/r3.4.14/zookeeperAdmin.html#sc_configuration # 通信心跳数,Zookeeper ...
- 快速定位XPATH
本文主要介绍如何快速定位WEB端的xpath. 浏览器:Chrome.火狐浏览器 两种浏览器的定位方法都是一样:按F12键,可查看开发者工具 上图,开发者工具最左上角是定位按钮,点击此按钮,再点击浏览 ...
- tex 进度条
\documentclass{beamer} \usepackage{tikz} \usetikzlibrary{calc} \definecolor{pbblue}{HTML}{0A75A8}% f ...
- [物理学与PDEs]第1章习题1 无限长直线的电场强度与电势
设有一均匀分布着电荷的无限长直线, 其上的电荷线密度 (即单位长度上的电荷量) 为 $\sigma$. 试求该直线所形成的电场的电场强度及电势. 解答: 设空间上点 $P$ 到直线的距离为 $r$, ...
- RT-SA-2019-004 Cisco RV320 Unauthenticated Diagnostic DataRetrieval
Advisory: Cisco RV320 Unauthenticated Diagnostic Data Retrieval RedTeam Pentesting discovered that t ...
- CSS盒模型(Box Model)
阅读目录 1. 什么是CSS盒模型 2. IE盒模型和W3C盒模型 3. CSS3属性box-sizing 4. 关于盒模型的使用 在最初接触CSS的时候,对于CSS盒模型的不了解,撞了很多次的南墙呀 ...