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 相关文章推荐
jQuery Ajax请求状态管理器打包
May 03 Javascript
一些常用弹出窗口/拖放/异步文件上传等实用代码
Jan 06 Javascript
百度判断手机终端并自动跳转js代码及使用实例
Jun 11 Javascript
AngularJS入门知识之MVW类框架的编程思想探讨
Dec 08 Javascript
Javascript基础教程之for循环
Jan 18 Javascript
vue之nextTick全面解析
May 17 Javascript
JavaScript调试之console.log调试的一个小技巧分享
Aug 07 Javascript
微信小程序实现流程进度的图样式功能
Jan 16 Javascript
angular6.0使用教程之父组件通过url传递id给子组件的方法
Jun 30 Javascript
JQuery实现ajax请求的示例和注意事项
Dec 10 jQuery
Vue中qs插件的使用详解
Feb 07 Javascript
vue实现简易的双向数据绑定
Dec 29 Vue.js
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
探讨:parse url解析URL,返回其组成部分
2013/06/14 PHP
PHP下载远程图片并保存到本地方法总结
2016/01/22 PHP
HR vs ForZe BO3 第一场 2.13
2021/03/10 DOTA
FLASH 广告之外的链接
2008/12/16 Javascript
轻轻松松学JS调试(不下载任何工具)
2010/04/14 Javascript
关于JavaScript对象的动态选择及遍历对象
2014/03/10 Javascript
seaJs的模块定义和模块加载浅析
2014/06/06 Javascript
Nodejs+express+html5 实现拖拽上传
2014/08/08 NodeJs
Javascript 读取操作Sql中的Xml字段
2014/10/09 Javascript
jQuery插件实现多级联动菜单效果
2015/12/01 Javascript
jQuery页面弹出框实现文件上传
2017/02/09 Javascript
Bootstrap警告框(Alert)插件使用方法
2017/03/21 Javascript
了解VUE的render函数的使用
2017/06/08 Javascript
vue项目优化之通过keep-alive数据缓存的方法
2017/12/11 Javascript
Layui Table js 模拟选中checkbox的例子
2019/09/03 Javascript
微信小程序tab切换可滑动切换导航栏跟随滚动实现代码
2019/09/04 Javascript
layui表格数据复选框回显设置方法
2019/09/13 Javascript
jQuery操作动画完整实例分析
2020/01/10 jQuery
详解Python中的元组与逻辑运算符
2015/10/13 Python
Python request设置HTTPS代理代码解析
2018/02/12 Python
Python流程控制 while循环实现解析
2019/09/02 Python
python groupby 函数 as_index详解
2019/12/16 Python
翻转数列python实现,求前n项和,并能输出整个数列的案例
2020/05/03 Python
numpy的Fancy Indexing和array比较详解
2020/06/11 Python
总结python 三种常见的内存泄漏场景
2020/11/20 Python
python实现经典排序算法的示例代码
2021/02/07 Python
使用phonegap播放音频的实现方法
2017/03/31 HTML / CSS
介绍一下SQL Server的全文索引
2013/08/15 面试题
上班看电影检讨书
2014/02/12 职场文书
心理健康日活动总结
2014/05/08 职场文书
2014年幼儿园小班工作总结
2014/12/04 职场文书
岗位聘任报告
2015/03/02 职场文书
校车安全管理责任书
2015/05/11 职场文书
辩护词格式
2015/05/22 职场文书
最新的离婚协议书范本!
2019/07/02 职场文书
nginx实现发布静态资源的方法
2021/03/31 Servers