

vue+koa2搭建mock数据环境
source link: http://rocky-191.github.io/2020/05/17/vue-koa2-mock-demo/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

前段时间写了一篇 前端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
当看到下图时,表示启动项目成功
改造前端项目
- 修改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数据了,大功告成。
这样以后就可以将mock数据的项目和具体前端项目分离开,更方便的使用。再也不用求着后端给mock数据了,自己搞!
Recommend
-
92
前言 因为自己的博客完全的前后端分离写的,在 seo 这一块也没考虑过,于是乎,便开始了本次的SSR之旅 技术栈 vue2 + koa2 + webpack4 + mongodb 因为webpack也已经到了 4.1 的版本了,所以顺带把webpack3迁移到
-
63
koa简单回顾 koa 内部对http请求、响应做了封装,同时提供了强大的中间件机制来方便开发者扩展koa的功能。一个koa版本的hello world如下所示:
-
64
Koa是基于Nodejs的一个后端框架,算是比较常用的,核心思想就是中间件,Koa实现底层逻辑,其余的就需要自己实现,包括:session、数据库操作、文件上传、路由、模板、静态资源访问等 前言 一直以来都是使用
-
42
Koa 就是一种简单好用的 Web 框架。它的特点是优雅、简洁、表达力强、自由度高 1.1 架设 HTTP 服务 只要三行代码,就可以用 Koa 架设一个 HTTP 服务。 co...
-
33
Node.js 是一个异步的世界,官方 API 支持的都是 callback 形式的异步编程模型,这 会带来许多问题,例如: callback Koa Koa – 基于 Node.js 平台的下一代 web 开发框...
-
16
一杯茶的时间,上手 Koa2 + MySQL 开发 2020-05-22 2020-10-06后端 ,...
-
39
QQ音乐API koa2实现 - 全接口实现RainyCGhttps://github.com/Rain120
-
19
Koa2 与它的中间件们 2019.06.25默认分类 0 评...
-
3
自己搭建项目让我们不仅仅关注于开发本身,知其然知其所以然,收获更多…虽然,对于新手来说,我们选择类似于koa-generator之类的脚手架,可以最快的入手koa2或者node项目。但是,自己搭建项目,更加适用于实际开发中前后端分离的定制化业务场景,且能让...
-
8
主要分为express和koa2两个框架由于node后端学习,得有一份接口文档,个人不是很喜欢swagger 本文主要在于避坑一、网上科普文章多、此文主要解决遇到的问题
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK