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 相关文章推荐
关于IE BUG与字符串截取substr的解决办法
Apr 10 Javascript
javascript在网页中实现读取剪贴板粘贴截图功能
Jun 07 Javascript
JavaScript动态插入CSS的方法
Dec 10 Javascript
js实现仿qq消息的弹出窗效果
Jan 06 Javascript
Node.js中process模块常用的属性和方法
Dec 13 Javascript
HTML5实现微信拍摄上传照片功能
Apr 21 Javascript
激动人心的 Angular HttpClient的源码解析
Jul 10 Javascript
使用puppeteer破解极验的滑动验证码
Feb 24 Javascript
vue-i18n结合Element-ui的配置方法
May 20 Javascript
微信小程序进入广告实现代码实例
Sep 19 Javascript
vue路由传参的基本实现方式小结【三种方式】
Feb 05 Javascript
vue祖孙组件之间的数据传递案例
Dec 07 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
PHP截取中文字符串的问题
2006/07/12 PHP
JS 网站性能优化笔记
2011/05/24 PHP
详谈PHP文件目录基础操作
2014/11/11 PHP
php从csv文件读取数据并输出到网页的方法
2015/03/14 PHP
PHP实现绘制二叉树图形显示功能详解【包括二叉搜索树、平衡树及红黑树】
2017/11/16 PHP
TP5(thinkPHP框架)实现后台清除缓存功能示例
2019/05/29 PHP
Laravel框架控制器的middleware中间件用法分析
2019/09/30 PHP
基于JavaScript实现 网页切出 网站title变化代码
2016/04/03 Javascript
最棒的Angular2表格控件
2016/08/10 Javascript
jQuery插件HighCharts绘制2D圆环图效果示例【附demo源码下载】
2017/03/09 Javascript
详解vue+vuex+koa2开发环境搭建及示例开发
2018/01/22 Javascript
JavaScript控制浏览器全屏显示简单示例
2018/07/05 Javascript
VUE 实现动态给对象增加属性,并触发视图更新操作示例
2019/11/29 Javascript
jQuery实现的图片点击放大缩小功能案例
2020/01/02 jQuery
原生JavaScript实现拖动校验功能
2020/09/29 Javascript
Python数组条件过滤filter函数使用示例
2014/07/22 Python
Python 使用requests模块发送GET和POST请求的实现代码
2016/09/21 Python
详解Python3 中hasattr()、getattr()、setattr()、delattr()函数及示例代码数
2018/04/18 Python
Python基于lxml模块解析html获取页面内所有叶子节点xpath路径功能示例
2018/05/16 Python
Python基于生成器迭代实现的八皇后问题示例
2018/05/23 Python
Python3使用SMTP发送带附件邮件
2020/06/16 Python
解决pycharm运行出错,代码正确结果不显示的问题
2018/11/30 Python
理想高通滤波实现Python opencv示例
2019/01/30 Python
python格式化输出保留2位小数的实现方法
2019/07/02 Python
python+tkinter实现学生管理系统
2019/08/20 Python
浅谈Tensorflow 动态双向RNN的输出问题
2020/01/20 Python
python基于win32api实现键盘输入
2020/12/09 Python
非洲NO.1网上商店:Jumia肯尼亚
2016/08/18 全球购物
拓展培训心得体会
2014/01/04 职场文书
代理班主任的自我评价
2014/02/04 职场文书
公交公司毕业生求职信
2014/02/15 职场文书
房屋买卖协议样本
2014/11/16 职场文书
2014年度安全工作总结
2014/12/04 职场文书
幼儿园父亲节活动总结
2015/02/12 职场文书
员工旷工检讨书
2015/08/15 职场文书
反腐倡廉心得体会2016
2016/01/13 职场文书