中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue-cli如何實現異步請求返回mock模擬數據

發布時間:2022-03-18 11:22:36 來源:億速云 閱讀:264 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“vue-cli如何實現異步請求返回mock模擬數據”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“vue-cli如何實現異步請求返回mock模擬數據”這篇文章吧。

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

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

開始實現

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

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

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

> npm install -g @vue-cli

  2、創建vue-cli項目:

> vue create vue-mock

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

  本示例使用的版本是vue-cli 4.5.13、vue3、webpack4,如果發現某個配置不生效,請留意是否已經被廢棄。

  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的區別,不再是通過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數據</button>
  </div>
</template>

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

</style>

這時候頁面效果如下:

vue-cli如何實現異步請求返回mock模擬數據

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

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

  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也出現了該請求,如下圖

vue-cli如何實現異步請求返回mock模擬數據

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

  10、安裝chokidar插件,監聽mock文件夾,實現接口路由熱更新,想了解更多chokidar的內容請自行搜索

> npm install chokidar -D

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

// 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') // 這里必須在函數內引用,否則無法實現熱更新
  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文件內容不會觸發自動更新,具體原因這里就不說了,可以自己想一想哦~

  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里面的返回數據,回到頁面點擊按鈕,發現返回數據已改變,到此,已實現接口請求返回mock數據。

以上是“vue-cli如何實現異步請求返回mock模擬數據”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

荥经县| 深泽县| 温州市| 松桃| 邛崃市| 黔西县| 庆阳市| 黔东| 贵港市| 罗田县| 奉化市| 徐水县| 商南县| 若尔盖县| 类乌齐县| 湘潭县| 天镇县| 平凉市| 邹城市| 无锡市| 无极县| 建湖县| 乡城县| 社旗县| 乌恰县| 绵竹市| 通化县| 桃园市| 牙克石市| 长泰县| 临泽县| 家居| 府谷县| 新建县| 洞头县| 城固县| 仁怀市| 筠连县| 濮阳市| 阿尔山市| 大理市|