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 相关文章推荐
js限制文本框为整数和货币的函数代码
Oct 13 Javascript
js预载入和JavaScript Image()对象使用介绍
Aug 28 Javascript
Javascript改变CSS样式(局部和全局)
Dec 18 Javascript
我的Node.js学习之路(二)NPM模块管理
Jul 06 Javascript
在bootstrap中实现轮播图实例代码
Jun 11 Javascript
vue使用vue-i18n实现国际化的实现代码
Apr 08 Javascript
jQuery实现左右两个列表框的内容相互移动功能示例
Jan 27 jQuery
详解JSON和JSONP劫持以及解决方法
Mar 08 Javascript
Angular7中创建组件/自定义指令/管道的方法实例详解
Apr 02 Javascript
vue-cli 3.x配置跨域代理的实现方法
Apr 12 Javascript
如何使用50行javaScript代码实现简单版的call,apply,bind
Aug 14 Javascript
JS+css3实现幻灯片轮播图
Aug 14 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
DOMXML函数笔记
2006/10/09 PHP
SSI指令
2006/11/25 PHP
PHP解析html类库simple_html_dom的转码bug
2014/05/22 PHP
thinkPHP统计排行与分页显示功能示例
2016/12/02 PHP
(推荐一个超好的JS函数库)S.Sams Lifexperience ScriptClassLib
2007/04/29 Javascript
javascript 表单规则集合对象
2009/07/21 Javascript
jQuery学习总结之元素的相对定位和选择器(持续更新)
2011/04/26 Javascript
动态加载js和css(外部文件)
2013/04/17 Javascript
jquery动态增加text元素以及删除文本内容实例代码
2013/07/01 Javascript
关于onchange事件在IE和FF下的表现及解决方法
2014/03/08 Javascript
用jquery写的菜单从左往右滑动出现
2014/04/11 Javascript
原生JS实现仿淘宝网左侧商品分类菜单效果代码
2015/09/10 Javascript
详解jQuery中的empty、remove和detach
2016/04/11 Javascript
js返回顶部实例分享
2016/12/21 Javascript
数组Array的排序sort方法
2017/02/17 Javascript
javascript实现动态显示颜色块的报表效果
2017/04/10 Javascript
微信小程序搜索组件wxSearch实例详解
2017/06/08 Javascript
Node.JS使用Sequelize操作MySQL的示例代码
2017/10/09 Javascript
AngularJS实现的生成随机数与猜数字大小功能示例
2017/12/25 Javascript
nodejs 简单实现动态html的方法
2018/05/12 NodeJs
[01:12:08]LGD vs OG 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.24
2019/09/10 DOTA
Python进阶-函数默认参数(详解)
2017/05/18 Python
Django Rest framework之权限的实现示例
2018/12/17 Python
用Python实现将一张图片分成9宫格的示例
2019/07/05 Python
Python PIL图片添加字体的例子
2019/08/22 Python
CSS3贝塞尔曲线示例:创建链接悬停动画效果
2020/11/19 HTML / CSS
HTML5自定义mp3播放器源码
2020/01/06 HTML / CSS
丝绸和人造花卉、植物和树木:Nearly Natural
2018/11/28 全球购物
美国最值得信赖的宠物药房:Allivet
2019/03/23 全球购物
java程序员面试交流
2012/11/29 面试题
增员口号大全
2014/06/18 职场文书
实习护士自荐信
2014/06/21 职场文书
毕业班工作总结
2015/08/10 职场文书
优秀乡村医生事迹材料(2016精选版)
2016/02/29 职场文书
vue如何实现关闭对话框后刷新列表
2022/04/08 Vue.js
Tomcat执行startup.bat出现闪退的原因及解决办法
2022/04/20 Servers