vue+koa2搭建mock数据环境的详细教程


Posted in Javascript onMay 18, 2020

前段时间写了一篇前端vue项目实现mock数据方式的文章,主要是在vue项目里使用mock数据,数据和项目耦合在一起,不太优雅,作为一个有追求的前端,怎么能容忍这种方法呢?特以此篇,记录利用koa2搭建服务端,提供mock数据的方法。

初始化vue项目

这里以vue项目为主,当然别的类型项目依然可以使用这种mock数据的方式。

vue create vue-koa2-demo

前提是安装了vue-cli的脚手架,我电脑安装的是vue-cli3的版本。按照要求一步一步选择后,记得选择安装vuex,后续要使用,启动项目。

koa2项目初始化

前端项目弄好之后,开始安装koa

mkdir koa-demo
cd koa-demo
npm koa koa-router koa-cors

安装工作完成后,在项目根目录下新建一个server.js.

let Koa=require('koa')
let Router=require('koa-router')
let cors=require('koa-cors')
let fs=require('fs')

const app=new Koa()
const router=new Router()

router.get('/getData',async ctx=>{
 // 允许cors跨域请求
 await cors();
 // 返回数据
 ctx.body=JSON.parse(fs.readFileSync('./static/data.json'));
})

// 将koa和中间件连起来
app.use(router.routes()).use(router.allowedMethods());

let port=3000;
app.listen(port,()=>{
 console.log('server is running on'+port)
})

上面请求了一个data.json。需要在项目根目录下新建文件夹static,新建data.json

[{
 "id": 1,
 "name": "曹操",
 "age": "18"
}, {
 "id": 2,
 "name": "孙权",
 "age": "20"
}, {
 "id": 3,
 "name": "刘备",
 "age": "24"
}, {
 "id": 4,
 "name": "魏延",
 "age": "28"
}]

在终端中执行命令启动koa项目

node server.js

当看到下图时,表示启动项目成功

vue+koa2搭建mock数据环境的详细教程

改造前端项目修改Home.vue文件

<template>
 <div class="home">
 <ul>
  <li v-for="item in list" :key="item.id">
  <p>姓名:{{ item.name }}</p>
  <p>年龄:{{ item.age }}</p>
  </li>
 </ul>
 </div>
</template>

<script>
export default {
 name: "Home",
 computed: {
 list() {
  return this.$store.state.list;
 }
 },
 mounted() {
 this.getlist();
 },
 methods: {
 getlist() {
  this.$store.dispatch('getData')
 }
 }
};
</script>

修改App.vue文件

<template>
 <div id="app">
 <router-view />
 </div>
</template>

修改store/index.js

import Vue from "vue";
import Vuex from "vuex";
import axios from "axios";

Vue.use(Vuex);

export default new Vuex.Store({
 state: {
 list: []
 },
 mutations: {
 setlist(state, data) {
  state.list = data;
 }
 },
 actions: {
 getData({ commit }) {
  axios
  .get("/api/getData", {
   headers: {
   Accept: "application/json",
   "Content-Type": "application/json"
   }
  })
  .then(res => {
   if (res.status === 200) {
   return res.data;
   }
  })
  .then(res => {
   commit("setlist", Array.from(res));
  });
 }
 },
 modules: {}
});

记得提前安装axios,这里需要使用axios请求后端接口。

新建配置文件

在根目录下新建一个vue.config.js,由于前后端项目存在跨域,需要使用代理实现。

module.exports = {
 devServer: {
 port: 8085, // 端口号
 https: false, // https:{type:Boolean}
 open: true, //配置自动启动浏览器
 proxy: {
  "/api": {
  target: "http://127.0.0.1:3000",
  changeOrigin: true,
  pathRewrite: {
   "^/api": "/"
  }
  }
 }
 }
};

重新启动项目

npm run serve

就会看到页面上显示出了koa-demo项目里定义的json数据了,大功告成。

vue+koa2搭建mock数据环境的详细教程

这样以后就可以将mock数据的项目和具体前端项目分离开,更方便的使用。再也不用求着后端给mock数据了,自己搞!

参考资料koa官网

总结

到此这篇关于vue+koa2搭建mock数据环境的详细教程的文章就介绍到这了,更多相关vue koa2 mock数据环境内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
javascript使用eval或者new Function进行语法检查
Oct 16 Javascript
Jquery焦点图实例代码
Nov 25 Javascript
JavaScript动态改变表格单元格内容的方法
Mar 30 Javascript
jQuery实现商品活动倒计时
Oct 16 Javascript
javascript图片预览和上传(兼容IE)
Mar 15 Javascript
使用JS实现气泡跟随鼠标移动的动画效果
Sep 16 Javascript
JQuery元素快速查找与操作
Apr 22 jQuery
webpack打包react项目的实现方法
Jun 21 Javascript
详解React 服务端渲染方案完美的解决方案
Dec 14 Javascript
浅谈layer的Icon样式以及一些常用的layer窗口使用方法
Sep 11 Javascript
VUE 直接通过JS 修改html对象的值导致没有更新到数据中解决方法分析
Dec 02 Javascript
vue实现一个矩形标记区域(rectangle marker)的方法
Oct 28 Javascript
Vue 基于 vuedraggable 实现选中、拖拽、排序效果
May 18 #Javascript
react 生命周期实例分析
May 18 #Javascript
react使用CSS实现react动画功能示例
May 18 #Javascript
Node.js API详解之 net模块实例分析
May 18 #Javascript
Javascript实现简易天数计算器
May 18 #Javascript
微信小程序开发打开另一个小程序的实现方法
May 17 #Javascript
微信小程序开发之获取用户手机号码(php接口解密)
May 17 #Javascript
You might like
PHP函数常用用法小结
2010/02/08 PHP
php守护进程 加linux命令nohup实现任务每秒执行一次
2011/07/04 PHP
不支持fsockopen但支持culr环境下下ucenter与modoer通讯问题
2011/08/12 PHP
php+redis实现多台服务器内网存储session并读取示例
2017/01/12 PHP
jQuery UI Dialog控件中的表单无法正常提交的解决方法
2010/12/19 Javascript
使用JS画图之点、线、面
2015/01/12 Javascript
JS简单模拟触发按钮点击功能的方法
2015/11/30 Javascript
Node.js开发者必须了解的4个JS要点
2016/02/21 Javascript
基于javascript数组实现图片轮播
2016/05/02 Javascript
对javascript继承的理解
2016/10/11 Javascript
关于jquery form表单序列化的注意事项详解
2017/08/01 jQuery
vue中遇到的坑之变化检测问题(数组相关)
2017/10/13 Javascript
vue富文本编辑器组件vue-quill-edit使用教程
2018/09/21 Javascript
使用PreloadJS加载图片资源的基础方法详解
2020/02/03 Javascript
ES6箭头函数和扩展实例分析
2020/05/23 Javascript
详解python OpenCV学习笔记之直方图均衡化
2018/02/08 Python
python 读取鼠标点击坐标的实例
2018/12/29 Python
python实现爬山算法的思路详解
2019/04/09 Python
python利用7z批量解压rar的实现
2019/08/07 Python
PyTorch中Tensor的拼接与拆分的实现
2019/08/18 Python
Python整数与Numpy数据溢出问题解决
2019/09/11 Python
Python动态导入模块:__import__、importlib、动态导入的使用场景实例分析
2020/03/30 Python
魅力惠奢品线上平台:MEI.COM
2016/11/29 全球购物
Allsole美国/加拿大:英国一家专门出售品牌鞋子的网站
2018/10/21 全球购物
摩飞电器俄罗斯官方网站:Morphy Richards俄罗斯
2020/07/30 全球购物
Java基础知识面试要点
2016/07/29 面试题
请写出 float x 与"零值"比较的 if 语句
2016/01/04 面试题
下面关于"联合"的题目的输出是什么
2013/08/06 面试题
小学生评语集锦
2014/04/18 职场文书
专科应届毕业生求职信
2014/06/04 职场文书
三八节标语
2014/06/27 职场文书
房贷收入证明范本
2015/06/12 职场文书
企业年会祝酒词
2015/08/11 职场文书
教你怎么用Python实现多路径迷宫
2021/04/29 Python
Python中Numpy和Matplotlib的基本使用指南
2021/11/02 Python
SQL试题 使用窗口函数选出连续3天登录的用户
2022/04/24 Oracle