前端vue项目实现mock数据方式
2020/5/6 11:26:55
本文主要是介绍前端vue项目实现mock数据方式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
前后端分离开发已成大势所趋,基本上大部分公司的开发模式都是如此,那如何自己本地实现一个数据mock呢?当然你也可以使用在线的工具,比如easymock也可以实现mock数据,但是如果追求稳定性,还是本地搭一套环境吧。下面我介绍的是使用了vue-cli本身自带的功能实现mock 数据。
初始化项目
(1)使用vue-cli初始化
vue create mock-demo 复制代码
全部采用默认即可
(2)创建配置文件
在项目根目录下创建vue.config.js配置文件。内容如下:
const bodyParser = require("body-parser"); const isProduction = process.env.NODE_ENV === "production"; let feMock; if (!isProduction) { feMock = require("./mockApi"); } module.exports = { publicPath: isProduction ? "././" : "", pages: { index: { entry: "src/main.js", template: "public/index.html", filename: "index.html" } }, devServer: { before: app => { // 关键代码 app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: true })); if (!isProduction) { feMock(app); } } } }; 复制代码
这里主要是利用了webpack-dev-server实现的mock功能,为了实现接口请求,当然需要提前安装axios,body-parser。
npm i axios body-parser -S 复制代码
编写mock的API
(1)在项目根目录新建文件夹mockApi,新建index.js
const feMock = app => { app.get("/mock/api/news", function(req, res) { res.json({ name: "tom" }); }); }; module.exports=feMock; 复制代码
(2)在src目录下新建一个api文件夹,新建文件index.js
const prefix = "/mock"; export default { methods: { _testMock() { return this.$http.get(`${prefix}/api/news`); } } }; 复制代码
这里的请求路径一定要和上一步mock数据的路径保持一致。等后端写好接口之后,统一修改此文件里的prefix接口即可。
组件使用
(1)在App.vue里使用
<script> import api from "./api"; export default { name: "App", mixins: [api], mounted() { this.testMock(); this.testMock1(); this.testPostMock(); }, methods: { testMock() { this._testMock() .then(res => { console.log(res); }) .catch(err => { console.log(err); }); } } }; </script> 复制代码
正常启动项目后,在浏览器network里就可以看到请求了,初始功能实现。
优化
(1)如果项目中多个人写多个mock文件怎么整呢?
(2)能不能直接扫描特定目录加载mock文件呢?是否可以有一个统一的对外入口,每个人只需要写自己的mock文件,不用修改出口?
解决办法
(1)在mockApi文件夹下新建一个mockList文件夹,之后所有人的mock接口写在这里。示例如下:
在mockList中新建一个test.js
function testMock(app) { app.get("/mock/api/news", function(req, res) { res.json({ name: "tom" }); }); } function testPostMock(app) { app.post("/mock/api/news", function(req, res) { console.log(req.body); setTimeout(function() { res.json({ code: 0, data: "success", desc: "" }); }, 500); }); } module.exports = [testMock, testPostMock]; 复制代码
在mockList中新建一个test1.js
function testMock1(app) { app.get("/mock/api/news1", function(req, res) { res.json({ name: "jack" }); }); } module.exports = [testMock1]; 复制代码
(2)修改mockApi/index.js文件
const fs = require("fs"); const path = __dirname; const files = fs.readdirSync(path + "/mockList"); const mockList = []; files.forEach(function(filename) { let model = require(path + "/mockList/" + filename); mockList.push(...model); }); function handleMock(app) { mockList.forEach(func => { func(app); }); } module.exports = handleMock; 复制代码
引入fs,自动读取设定目录下的文件,这样配置好之后,其他人只管写自己的mock接口,不需要去修改这个对外的文件,这样就完美解决了。
示例代码目录结构如下:
这篇关于前端vue项目实现mock数据方式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-04package.json 文件位置在哪?-icode9专业技术文章分享
- 2024-10-01Craco.js学习:从入门到实践指南
- 2024-10-01Create-React-App学习:入门与实践指南
- 2024-10-01CSS-in-JS学习:从入门到实践指南
- 2024-09-30JSX语法学习:从入门到初步掌握
- 2024-09-30Mock.js学习:入门教程与实战演练
- 2024-09-30React Hooks学习:从入门到实践
- 2024-09-30受控组件学习:React中的基础入门教程
- 2024-09-29JS定时器教程:初学者必看指南
- 2024-09-29JS对象教程:初学者的全面指南