vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細(xì)教程
前段時間寫了一篇前端vue項目實現(xiàn)mock數(shù)據(jù)方式的文章,主要是在vue項目里使用mock數(shù)據(jù),數(shù)據(jù)和項目耦合在一起,不太優(yōu)雅,作為一個有追求的前端,怎么能容忍這種方法呢?特以此篇,記錄利用koa2搭建服務(wù)端,提供mock數(shù)據(jù)的方法。
初始化vue項目
這里以vue項目為主,當(dāng)然別的類型項目依然可以使用這種mock數(shù)據(jù)的方式。
vue create vue-koa2-demo
前提是安裝了vue-cli的腳手架,我電腦安裝的是vue-cli3的版本。按照要求一步一步選擇后,記得選擇安裝vuex,后續(xù)要使用,啟動項目。
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();
// 返回數(shù)據(jù)
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": "孫權(quán)",
"age": "20"
}, {
"id": 3,
"name": "劉備",
"age": "24"
}, {
"id": 4,
"name": "魏延",
"age": "28"
}]
在終端中執(zhí)行命令啟動koa項目
node server.js
當(dāng)看到下圖時,表示啟動項目成功

改造前端項目修改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,由于前后端項目存在跨域,需要使用代理實現(xiàn)。
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數(shù)據(jù)了,大功告成。

這樣以后就可以將mock數(shù)據(jù)的項目和具體前端項目分離開,更方便的使用。再也不用求著后端給mock數(shù)據(jù)了,自己搞!
參考資料koa官網(wǎng)
總結(jié)
到此這篇關(guān)于vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細(xì)教程的文章就介紹到這了,更多相關(guān)vue koa2 mock數(shù)據(jù)環(huán)境內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue本地模擬服務(wù)器請求mock數(shù)據(jù)的方法詳解
- 詳解vue-cli項目中用json-sever搭建mock服務(wù)器
- 在vue中使用express-mock搭建mock服務(wù)的方法
- Vue利用mockjs編寫假數(shù)據(jù)并應(yīng)用的問題記錄
- Vue+Mockjs模擬curd接口請求的示例詳解
- Mock.js在Vue項目中的使用小結(jié)
- vue?中簡單使用mock的示例代碼詳解
- Vue項目中使用mock.js的完整步驟
- vue項目中mock.js的使用及基本用法
- Vue+Mock.js模擬登錄和表格的增刪改查功能
- 在Vue框架中配置Mock服務(wù)器的方法
相關(guān)文章
vue自定義指令實現(xiàn)元素滑動移動端適配及邊界處理
這篇文章主要為大家介紹了vue自定義指令實現(xiàn)元素滑動移動端適配及邊界處理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
vue使用axios?post發(fā)送json數(shù)據(jù)跨域請求403的解決方案
這篇文章主要介紹了vue使用axios?post發(fā)送json數(shù)據(jù)跨域請求403的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
關(guān)于element?ui的菜單default-active默認(rèn)選中的問題
這篇文章主要介紹了關(guān)于element?ui的菜單default-active默認(rèn)選中的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05
Vue3中Provide?/?Inject的實現(xiàn)原理分享
provide和inject主要為高階插件/組件庫提供用例,這篇文章主要給大家介紹了關(guān)于Vue3中Provide?/?Inject的實現(xiàn)原理,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02
vue-element-admin 菜單標(biāo)簽失效的解決方式
今天小編就為大家分享一篇vue-element-admin 菜單標(biāo)簽失效的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
Vue使用provide各種傳值后inject獲取undefined的問題及解決
這篇文章主要介紹了Vue使用provide各種傳值后inject獲取undefined的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08

