国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細(xì)教程

瀏覽:5日期:2023-01-20 13:46:39

前段時(shí)間寫了一篇前端vue項(xiàng)目實(shí)現(xiàn)mock數(shù)據(jù)方式的文章,主要是在vue項(xiàng)目里使用mock數(shù)據(jù),數(shù)據(jù)和項(xiàng)目耦合在一起,不太優(yōu)雅,作為一個(gè)有追求的前端,怎么能容忍這種方法呢?特以此篇,記錄利用koa2搭建服務(wù)端,提供mock數(shù)據(jù)的方法。

初始化vue項(xiàng)目

這里以vue項(xiàng)目為主,當(dāng)然別的類型項(xiàng)目依然可以使用這種mock數(shù)據(jù)的方式。

vue create vue-koa2-demo

前提是安裝了vue-cli的腳手架,我電腦安裝的是vue-cli3的版本。按照要求一步一步選擇后,記得選擇安裝vuex,后續(xù)要使用,啟動(dòng)項(xiàng)目。

koa2項(xiàng)目初始化

前端項(xiàng)目弄好之后,開始安裝koa

mkdir koa-democd koa-demonpm koa koa-router koa-cors

安裝工作完成后,在項(xiàng)目根目錄下新建一個(gè)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跨域請(qǐng)求 await cors(); // 返回?cái)?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)})

上面請(qǐng)求了一個(gè)data.json。需要在項(xiàng)目根目錄下新建文件夾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í)行命令啟動(dòng)koa項(xiàng)目

node server.js

當(dāng)看到下圖時(shí),表示啟動(dòng)項(xiàng)目成功

vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細(xì)教程

改造前端項(xià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請(qǐng)求后端接口。

新建配置文件

在根目錄下新建一個(gè)vue.config.js,由于前后端項(xiàng)目存在跨域,需要使用代理實(shí)現(xiàn)。

module.exports = { devServer: { port: 8085, // 端口號(hào) https: false, // https:{type:Boolean} open: true, //配置自動(dòng)啟動(dòng)瀏覽器 proxy: { '/api': { target: 'http://127.0.0.1:3000', changeOrigin: true, pathRewrite: { '^/api': '/' } } } }};

重新啟動(dòng)項(xiàng)目

npm run serve

就會(huì)看到頁面上顯示出了koa-demo項(xiàng)目里定義的json數(shù)據(jù)了,大功告成。

vue+koa2搭建mock數(shù)據(jù)環(huán)境的詳細(xì)教程

這樣以后就可以將mock數(shù)據(jù)的項(xiàng)目和具體前端項(xiàng)目分離開,更方便的使用。再也不用求著后端給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)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 一级做a爰片久久毛片欧美 一级做a爰片久久毛片人呢 | 欧美一级片免费 | 日韩一级免费视频 | 免费黄色成人 | 欧美日韩视频精品一区二区 | 亚洲国产精品影院 | 成人精品视频一区二区三区 | 国产精品视频免费播放 | 美女视频永久黄网站在线观看 | 日韩亚 | 亚洲第一页在线播放 | 国产一区二区久久精品 | 一级毛片子 | 99精品视频观看 | 亚洲精品在线免费 | 国产精品99r8在线观看 | 亚洲第一狼人区 | 自拍偷拍视频在线观看 | 午夜视频网站 | 午夜美女影院 | 久草免费小视频 | 日韩在线 中文字幕 | 最近日本免费观看视频 | 久草在线首页 | 亚洲码一区二区三区 | 女人张腿让男桶免费视频网站 | 亚洲一区在线视频观看 | 91在线成人 | 97视频免费在线 | 国产成人自拍在线 | 一级片在线播放 | 另类亚洲视频 | 亚洲国产精品免费观看 | 国产免费福利体检区久久 | 欧美高清在线精品一区 | 日本欧美久久久久免费播放网 | 美女福利视频午夜在线 | 亚洲国产天堂久久综合网站 | 美女一级片 | 亚洲欧美精品一中文字幕 | 秘书高跟黑色丝袜国产91在线 |