欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue-cli實現(xiàn)異步請求返回mock模擬數(shù)據(jù)

 更新時間:2022年03月18日 10:45:33   作者:飛天狼  
網(wǎng)上有不少使用mockjs模擬數(shù)據(jù)的文章,但基本都是本地攔截請求返回數(shù)據(jù),本文主要介紹了vue-cli實現(xiàn)異步請求返回mock模擬數(shù)據(jù),文中根據(jù)實例編碼詳細介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下

  在前后端分離開發(fā)的過程中,前端開發(fā)過程中,頁面的數(shù)據(jù)顯示一般都是寫死的靜態(tài)數(shù)據(jù),也就是沒有經(jīng)過接口,直接寫死在代碼中的,在后端給出接口后,再替換為接口數(shù)據(jù),為了減少對接成本,mock就出現(xiàn)了。通過預先跟服務器端約定好的接口,模擬請求數(shù)據(jù)甚至邏輯,能夠讓前端開發(fā)更加獨立自主,不會被服務端的開發(fā)所阻塞。

  網(wǎng)上有不少使用mockjs模擬數(shù)據(jù)的文章,但基本都是本地攔截請求返回數(shù)據(jù),在network中沒有發(fā)出任何的請求,本地調(diào)試起來很不好,只能通過console.log來調(diào)試。為了實現(xiàn)真正的異步請求,那么就需要真正的服務器接口,而在開發(fā)vue-cli項目時,本地開發(fā)運行啟動命令后,實際就是啟動了一個本地服務器,那么只要把接口地址都在本地服務器中配置并使用mock返回數(shù)據(jù)就可以實現(xiàn)真正的異步請求了,這樣調(diào)試就和真正的請求一模一樣了。

開始實現(xiàn)

  因為是vue-cli項目,請先安裝node和npm。

  1、首先,需要全局安裝vue-cli:

 1、首先,需要全局安裝vue-cli:

> npm install -g @vue-cli

  2、創(chuàng)建vue-cli項目:

> vue create vue-mock

  創(chuàng)建成功后進入項目根目錄,運行npm run serve啟動,應該可以成功訪問vue示例頁面  

  本示例使用的版本是vue-cli 4.5.13、vue3、webpack4,如果發(fā)現(xiàn)某個配置不生效,請留意是否已經(jīng)被廢棄。

  3、安裝axios

> npm install axios -S

  4、main.js添加aixos,修改如下

// main.js
import { createApp } from 'vue'
import App from './App.vue'
import axios from 'axios'

const vueApp = createApp(App)
vueApp.config.globalProperties.$axios = axios // vue3與vue2的區(qū)別,不再是通過prototype
vueApp.mount('#app')

  5、安裝mockjs

> npm install mockjs -D

  6、在根目錄新建mock文件夾,在mock文件夾下新建index.js文件,并在main.js中引入index.js,代碼如下:

// mock/index.js
import Mock from 'mockjs'
Mock.mock('/url', 'get', (req, res) => {
  return Mock.mock({
    status: 200,
    req,
    res,
    data: '請求成功'
  })
})
// main.js
import { createApp } from 'vue'
import App from './App.vue'
import axios from 'axios'
import '../mock/index' // 引入mock路由攔截
const vueApp = createApp(App)
vueApp.config.globalProperties.$axios = axios
vueApp.mount('#app')

  7、修改helloWorld.vue文件如下:

// helloWorld.vue
<template>
  <div>
    <button @click="getMockData">獲取mock數(shù)據(jù)</button>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  methods: {
    getMockData() {
      this.$axios.get('/url').then(res => {
        console.log(res)
      })
    }
  }
}
</script>
<style scoped>

</style>

這時候頁面效果如下:

  到了這一步可以說是成功實現(xiàn)mock數(shù)據(jù)返回了,細心的朋友可能已經(jīng)發(fā)現(xiàn),network里面并沒有出現(xiàn)請求,我們只能通過console查看返回結(jié)果,當請求數(shù)量多時就不太好調(diào)試了,那有沒有什么辦法可以讓請求出現(xiàn)在network中呢?

  前面已經(jīng)說到運行項目時,就是啟動了一個本地服務器,只要想辦法把接口路由配置進去就可以了,接著往下看

  9、修改vue.config.js中的devServer的配置,如果沒有該文件則新建

// vue.config.js
const Mock = require('mockjs')
module.exports = {
  //...
  devServer: {
    port: 8082,
    before: function(app, server) { // webpack4使用before,webpack使用setupMiddlewares
      app.get('/url', function(req, res) {
        res.json(Mock.mock({
          status: 200,
          data: '請求成功啦~'
        }));
      });
    }
  }
};

   注釋main.js中引入的mock配置

import { createApp } from 'vue'
import App from './App.vue'
import axios from 'axios'
// import '../mock/index' // 引入mock路由攔截
const vueApp = createApp(App)
vueApp.config.globalProperties.$axios = axios
vueApp.mount('#app')

  重啟服務,重新點擊按鈕,成功請求,并且在network也出現(xiàn)了該請求,如下圖

  這樣似乎已經(jīng)實現(xiàn)了我們的目的了,既使用了mock模擬數(shù)據(jù),也方便了調(diào)試,但是,在我們修改了返回的數(shù)據(jù)內(nèi)容時,請求接口,發(fā)現(xiàn)還是原來的數(shù)據(jù),因為是修改配置文件,所以每次修改都需要重啟服務,這也太麻煩了吧,我們想每次修改before里的內(nèi)容時,服務器都能夠自動熱更新,就像修改其他文件一樣,瀏覽器自動更新,繼續(xù)往下走。

  10、安裝chokidar插件,監(jiān)聽mock文件夾,實現(xiàn)接口路由熱更新,想了解更多chokidar的內(nèi)容請自行搜索

> npm install chokidar -D

  11、在mock文件夾下新建mock-server.js,內(nèi)容如下,就不具體細說了,大家可以自行調(diào)試

// mock/mock-server.js
const chokidar = require('chokidar')
const path = require('path')

const mockDir = path.join(process.cwd(), 'mock')

// 刪除對應的接口路由緩存
function removeRegisterRoutes() {
  Object.keys(require.cache).forEach(i => {
    if (i.includes(mockDir)) {
      console.log(i)
      delete require.cache[require.resolve(i)]
    }
  })
}
// 注冊接口路由,每增加一個路由,app._router.stack就增加一個堆棧
function registerRoutes(app){
  const mocks = require('./index') // 這里必須在函數(shù)內(nèi)引用,否則無法實現(xiàn)熱更新
  let count = 0
  for (const mock of mocks) {
    app[mock.method](mock.url, mock.response);
    count++
  }
  return {
    start: app._router.stack.length - count,
    count
  }
}

module.exports = (app) => {
  let { start, count } = registerRoutes(app)
  chokidar.watch(mockDir, {}).on('all', (event, path) => {
    if (event === 'change' || event === 'add') {
      app._router.stack.splice(start, count) // 先刪除舊的api路由,再重新注冊新的路由
      removeRegisterRoutes()
      const stack = registerRoutes(app)
      start = stack.start
      count = stack.count
    }
  })
}

  注意,修改mock-server.js文件內(nèi)容不會觸發(fā)自動更新,具體原因這里就不說了,可以自己想一想哦~

  12、修改mock中的index.js文件

// mock/index.jsconst Mock = require('mockjs')

const routers = [
  {
    url: '/url',
    method: 'get',
    response: (req, res) => {
      res.json(Mock.mock({
        status: 200,
        data: '請求成功~'
      }))
    }
  },
  {
    url: '/url/path',
    method: 'get',
    response: (req, res) => {
      res.json(Mock.mock({
        status: 200,
        data: '請求接口/url/path'
      }))
    }
  }
]
module.exports = routers

  13、修改vue.config.js的beforte

// vue.config.js// const Mock = require('mockjs')
module.exports = {
  //...
  devServer: {
    port: 8082,
    before: require('./mock/mock-server')
  }
};

  重新啟動,點擊按鈕,請求成功,修改mock中的index里面的返回數(shù)據(jù),回到頁面點擊按鈕,發(fā)現(xiàn)返回數(shù)據(jù)已改變,到此,已實現(xiàn)接口請求返回mock數(shù)據(jù)。

到此這篇關(guān)于vue-cli實現(xiàn)異步請求返回mock模擬數(shù)據(jù)的文章就介紹到這了,更多相關(guān)vue-cli異步請求返回mock內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue 1.0 結(jié)合animate.css定義動畫效果

    vue 1.0 結(jié)合animate.css定義動畫效果

    本文分步驟給大家介紹了Vue 1.0自定義動畫效果,vue1.0代碼結(jié)合animate.css定義動畫,頁面一定要引入animate.cdd,具體實例代碼大家參考下本文
    2018-07-07
  • 詳解vue大文件視頻切片上傳的處理方法

    詳解vue大文件視頻切片上傳的處理方法

    前端上傳大文件、視頻的時候會出現(xiàn)超時、過大、很慢等情況,為了解決這一問題,跟后端配合做了一個切片的功能,接下來就詳細的給大家介紹一下vue大文件視頻切片上傳的處理方法,需要的朋友可以參考下
    2023-08-08
  • Vue3.0 響應式系統(tǒng)源碼逐行分析講解

    Vue3.0 響應式系統(tǒng)源碼逐行分析講解

    這篇文章主要介紹了Vue3.0 響應式系統(tǒng)源碼逐行分析講解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • VUE開發(fā)分布式醫(yī)療掛號系統(tǒng)的醫(yī)院設(shè)置頁面步驟

    VUE開發(fā)分布式醫(yī)療掛號系統(tǒng)的醫(yī)院設(shè)置頁面步驟

    這篇文章主要為大家介紹了VUE開發(fā)分布式醫(yī)療掛號系統(tǒng)的醫(yī)院設(shè)置頁面步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-04-04
  • 淺談Vue.js中如何實現(xiàn)自定義下拉菜單指令

    淺談Vue.js中如何實現(xiàn)自定義下拉菜單指令

    這篇文章主要介紹了淺談Vue.js中如何實現(xiàn)自定義下拉菜單指令,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Vue源碼之關(guān)于vm.$delete()/Vue.use()內(nèi)部原理詳解

    Vue源碼之關(guān)于vm.$delete()/Vue.use()內(nèi)部原理詳解

    這篇文章主要介紹了Vue源碼之關(guān)于vm.$delete()/Vue.use()內(nèi)部原理詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 詳解Weex基于Vue2.0開發(fā)模板搭建

    詳解Weex基于Vue2.0開發(fā)模板搭建

    這篇文章主要介紹了詳解Weex基于Vue2.0開發(fā)模板搭建,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • vue3不同環(huán)境下實現(xiàn)配置代理

    vue3不同環(huán)境下實現(xiàn)配置代理

    這篇文章主要介紹了vue3不同環(huán)境下實現(xiàn)配置代理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue?props傳入function時的this指向問題解讀

    Vue?props傳入function時的this指向問題解讀

    這篇文章主要介紹了Vue?props傳入function時的this指向問題解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue動態(tài)類的幾種使用方法總結(jié)

    Vue動態(tài)類的幾種使用方法總結(jié)

    這篇文章主要介紹了Vue動態(tài)類的幾種使用方法總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01

最新評論