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 相关文章推荐
推荐17个优美新鲜的jQuery的工具提示插件
Sep 14 Javascript
javascript中的五种基本数据类型
Aug 26 Javascript
jquery实现通用的内容渐显Tab选项卡效果
Sep 07 Javascript
javascript设置页面背景色及背景图片的方法
Dec 29 Javascript
javascript数组对象常用api函数小结(连接,插入,删除,反转,排序等)
Sep 20 Javascript
JavaScript实现获取远程的html到当前页面中
Mar 26 Javascript
jQuery.form.js的使用详解
Jun 14 jQuery
vue实现表格增删改查效果的实例代码
Jul 18 Javascript
Django使用多数据库的方法
Sep 06 Javascript
深入理解Vue 单向数据流的原理
Nov 09 Javascript
vue使用codemirror的两种用法
Aug 27 Javascript
js实现简单放大镜效果
Mar 07 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使用GD库创建图片缩略图的方法
2015/06/10 PHP
yii2.0实现验证用户名与邮箱功能
2015/12/22 PHP
php post json参数的传递和接收处理方法
2018/05/31 PHP
Jquery 基础学习笔记
2009/05/29 Javascript
基于jquery的大众点评,分类导航实现代码
2011/08/23 Javascript
js获取键盘按键响应事件(兼容各浏览器)
2013/05/16 Javascript
JavaScript把数组作为堆栈使用的方法
2015/03/20 Javascript
JavaScript获取当前网页标题(title)的方法
2015/04/03 Javascript
纯css下拉菜单 无需js
2016/08/15 Javascript
axios中cookie跨域及相关配置示例详解
2017/12/20 Javascript
vue模式history下在iis中配置流程
2019/04/17 Javascript
一篇文章带你使用Typescript封装一个Vue组件(简单易懂)
2020/06/05 Javascript
python类:class创建、数据方法属性及访问控制详解
2016/07/25 Python
Python计算两个日期相差天数的方法示例
2017/05/23 Python
对Python中DataFrame按照行遍历的方法
2018/04/08 Python
解决pandas 作图无法显示中文的问题
2018/05/24 Python
Python将一个CSV文件里的数据追加到另一个CSV文件的方法
2018/07/04 Python
python取数作为临时极大值(极小值)的方法
2018/10/15 Python
python读取txt文件,去掉空格计算每行长度的方法
2018/12/20 Python
Python Flask 搭建微信小程序后台详解
2019/05/06 Python
想学画画?python满足你!
2020/12/24 Python
css3边框_动力节点Java学院整理
2017/07/11 HTML / CSS
美国性感女装网站:bebe
2017/03/04 全球购物
电子狗项圈:eDog Australia
2019/12/04 全球购物
LVMH旗下最大的奢侈品网站平台:24S
2020/05/24 全球购物
人事部主管岗位职责
2013/12/26 职场文书
计算机科学系职业生涯规划书
2014/03/08 职场文书
英语分层教学实施方案
2014/06/15 职场文书
中学清明节活动总结
2014/07/04 职场文书
不错的求职信范文
2014/07/20 职场文书
2014年精神文明建设工作总结
2014/11/19 职场文书
2014年司法局工作总结
2014/12/11 职场文书
运动会1000米加油稿
2015/07/21 职场文书
求职信:会计求职的写作技巧
2019/04/24 职场文书
如何写好活动总结
2019/06/21 职场文书
详解SQL的窗口函数
2022/04/21 Oracle