溫馨提示×

溫馨提示×

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

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

vue項(xiàng)目中怎么使用mock數(shù)據(jù)接口

發(fā)布時(shí)間:2021-06-17 17:06:01 來源:億速云 閱讀:346 作者:Leah 欄目:web開發(fā)

本篇文章為大家展示了vue項(xiàng)目中怎么使用mock數(shù)據(jù)接口,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

1.使用devServer.before進(jìn)行數(shù)據(jù)mock

//通過配置devServer.before選項(xiàng),設(shè)置url訪問路徑及response響應(yīng)數(shù)據(jù),進(jìn)行mock數(shù)據(jù)。
const { data } = require('./data.json')
// 引入json數(shù)據(jù)對象

//vue.config.js配置文件中進(jìn)行Vue CLI的配置
module.exports = {
 //...
 devServer: {
  before: function(app, server) {
   app.get('/api/data', function(req, res) {
    res.json({ data: data, errno: 0 });
   });
  }
 }
};
import axios from 'axios'
const ERRNO = 0

//通過函數(shù)柯力化,接收url作為參數(shù),以返回新的函數(shù)接收額外的參數(shù)作為axios配置項(xiàng)
function get (url) {
 return function (params) {
  return axios.get(url, {
   params
  }).then((res) => {
   const { errno, data } = res.data
   if (errno === ERRNO) {
    return data
   }
  }).catch((e) => {
  })
 }
}

const getData = get('api/data')

getSeller().then(res => {
 console.log(res)
})

2.使用Mock.js進(jìn)行數(shù)據(jù)mock

使用Mock.mock(),根據(jù)數(shù)據(jù)模板生成模擬數(shù)據(jù)。

import Mock from 'mockjs'
import data from './bookHome'
//導(dǎo)入存放模擬json數(shù)據(jù)的js文件


Mock.mock(/\/api\/data/, 'get', home)
//表示需要攔截的 URL,可以是 URL 字符串或 URL 正則。
//表示需要攔截的 Ajax 請求類型。例如 GET、POST、PUT、DELETE 等。
//表示數(shù)據(jù)模板,可以是對象或字符串。例如 { 'data|1-10':[{}] }、'@EMAIL'。
/* axios獲取mock數(shù)據(jù) */
import axios from 'axios'

export function getData() {
 return axios({
  method: 'get',
  url: `${process.env.VUE_APP_BOOK_URL}/api/data`
  //通過環(huán)境指定的默認(rèn)地址設(shè)定接口url,方便后續(xù)調(diào)用
 })
}


 //接口方法返回promise對象,最終獲取mock數(shù)據(jù)
 getData().then(response => {
  if (response && response.status === 200) {
   const data = response.data
   console.log(data)
  }
 })

上述內(nèi)容就是vue項(xiàng)目中怎么使用mock數(shù)據(jù)接口,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI