Vue2 配置 Axios api 接口調(diào)用文件的方法
前情回顧
在上一篇中,我們通過配置基本的信息,已經(jīng)讓我們的項目能夠正常的跑起來了。但是,這里還沒有涉及到 AJAX 請求接口的內(nèi)容。
vue 本身是不支持 ajax 接口請求的,所以我們需要安裝一個接口請求的 npm 包,來使我們的項目擁有這個功能。
這其實是一個重要的 unix 思想,就是一個工具只做好一件事情,你需要額外的功能的時候,則需要安裝對應(yīng)的軟件來執(zhí)行。如果你以前是一個 jquery 重度用戶,那么可能理解這個思想一定要深入的理解。
支持 ajax 的工具有很多。一開始,我使用的是 superagent 這個工具。但是我發(fā)現(xiàn)近一年來,絕大多數(shù)的教程都是使用的 axios 這個接口請求工具。其實,這本來是沒有什么差別的。但是為了防止你們在看了我的博文和其他的文章之后,產(chǎn)生理念上的沖突。因此,我也就改用 axios 這個工具了。
本身, axios 這個工具已經(jīng)做了很好的優(yōu)化和封裝。但是,在使用的時候,還是略顯繁瑣,因此,我重新封裝了一下。當(dāng)然,更重要的是,封裝 axios 這個工具是為了和我以前寫的代碼的兼容。不過我封裝得很好,也推薦大家使用。
封裝 axios 工具,編輯 src/api/index.js 文件
首先,我們要使用 axios 工具,就必須先安裝 axios 工具。執(zhí)行下面的命令進行安裝
npm install axios -D

由于宿舍翻墻條件不好,這里使用 cnpm 替代
這樣,我們就安裝好了 axios 工具了。
還記得我們在第三篇博文中整理的系統(tǒng)結(jié)構(gòu)嗎?我們新建了一個 src/api/index.js 這個空文本文件,就那么放在那里了。這里,我們給它填寫上內(nèi)容。
// 配置API接口地址
var root = 'https://cnodejs.org/api/v1'
// 引用axios
var axios = require('axios')
// 自定義判斷元素類型JS
function toType (obj) {
return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase()
}
// 參數(shù)過濾函數(shù)
function filterNull (o) {
for (var key in o) {
if (o[key] === null) {
delete o[key]
}
if (toType(o[key]) === 'string') {
o[key] = o[key].trim()
} else if (toType(o[key]) === 'object') {
o[key] = filterNull(o[key])
} else if (toType(o[key]) === 'array') {
o[key] = filterNull(o[key])
}
}
return o
}
/*
接口處理函數(shù)
這個函數(shù)每個項目都是不一樣的,我現(xiàn)在調(diào)整的是適用于
https://cnodejs.org/api/v1 的接口,如果是其他接口
需要根據(jù)接口的參數(shù)進行調(diào)整。參考說明文檔地址:
https://cnodejs.org/topic/5378720ed6e2d16149fa16bd
主要是,不同的接口的成功標(biāo)識和失敗提示是不一致的。
另外,不同的項目的處理方法也是不一致的,這里出錯就是簡單的alert
*/
function apiAxios (method, url, params, success, failure) {
if (params) {
params = filterNull(params)
}
axios({
method: method,
url: url,
data: method === 'POST' || method === 'PUT' ? params : null,
params: method === 'GET' || method === 'DELETE' ? params : null,
baseURL: root,
withCredentials: false
})
.then(function (res) {
if (res.data.success === true) {
if (success) {
success(res.data)
}
} else {
if (failure) {
failure(res.data)
} else {
window.alert('error: ' + JSON.stringify(res.data))
}
}
})
.catch(function (err) {
let res = err.response
if (err) {
window.alert('api error, HTTP CODE: ' + res.status)
}
})
}
// 返回在vue模板中的調(diào)用接口
export default {
get: function (url, params, success, failure) {
return apiAxios('GET', url, params, success, failure)
},
post: function (url, params, success, failure) {
return apiAxios('POST', url, params, success, failure)
},
put: function (url, params, success, failure) {
return apiAxios('PUT', url, params, success, failure)
},
delete: function (url, params, success, failure) {
return apiAxios('DELETE', url, params, success, failure)
}
}
好,我們寫好這個文件之后,保存。
2017年10月20日補充,刪除了評論中有人反映會出錯的 return ,確實這個 return 是沒有什么作用的。不過我這邊確實沒出錯。沒關(guān)系啦,本來就沒啥用,只是一個以前的不好的習(xí)慣代碼。
有關(guān) axios 的更多內(nèi)容,請參考官方 github: https://github.com/mzabriskie/axios ,中文資料自行百度。
但就是這樣,我們還不能再 vue 模板文件中使用這個工具,還需要調(diào)整一下 main.js 文件。
調(diào)整 main.js 綁定 api/index.js 文件
這次呢,我們沒有上來就調(diào)整 main.js 文件,因為原始文件就配置得比較好,我就沒有刻意的想要調(diào)整它。
原始文件如下:
import Vue from 'vue'
import App from './App'
import router from './router'
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
template: '<App/>',
components: { App }
})
我們插入以下代碼:
// 引用API文件
import api from './api/index.js'
// 將API方法綁定到全局
Vue.prototype.$api = api
也就是講代碼調(diào)整為:
import Vue from 'vue'
import App from './App'
import router from './router'
// 引用API文件
import api from './api/index.js'
// 將API方法綁定到全局
Vue.prototype.$api = api
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
template: '<App/>',
components: { App }
})
好了,這樣,我們就可以在項目中使用我們封裝的 api 接口調(diào)用文件了。
測試一下看看能不能調(diào)通
我們來修改一下 src/page/index.vue 文件,將代碼調(diào)整為以下代碼:
<template>
<div>index page</div>
</template>
<script>
export default {
created () {
this.$api.get('topics', null, r => {
console.log(r)
})
}
}
</script>
好,這里是調(diào)用 cnodejs.org 的 topics 列表接口,并且將結(jié)果打印出來。
我們在瀏覽器中打開控制臺,看看 console 下面有沒有輸出入下圖一樣的內(nèi)容。如果有的話,就說明我們的接口配置已經(jīng)成功了。

cnodejs.org 接口數(shù)據(jù)演示
好,如果你操作正確,代碼沒有格式錯誤的話,那么現(xiàn)在應(yīng)該得到的結(jié)果是和我一樣的。如果出錯或者怎么樣,請仔細(xì)的檢查代碼,看看有沒有什么問題。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vite+vue3+element-plus項目搭建的方法步驟
因為vue3出了一段時間了,element也出了基于vue3.x版本的element-plus,vite打包聽說很快,嘗試一下,感興趣的可以了解一下2021-06-06
vant-ui框架的一個bug(解決切換后onload不觸發(fā))
這篇文章主要介紹了vant-ui框架的一個bug(解決切換后onload不觸發(fā)),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue router解決路由帶參數(shù)跳轉(zhuǎn)時出現(xiàn)404問題
我的頁面是從一個vue頁面router跳轉(zhuǎn)到另一個vue頁面,并且利用windows.open() 瀏覽器重新創(chuàng)建一個頁簽,但是不知道為什么有時候可以有時候又不行,所以本文給大家介紹了vue router解決路由帶參數(shù)跳轉(zhuǎn)時出現(xiàn)404問題,需要的朋友可以參考下2024-03-03
electron + vue項目實現(xiàn)打印小票功能及實現(xiàn)代碼
這篇文章主要介紹了electron + vue項目實現(xiàn)打印小票功能,需要的朋友可以參考下2018-11-11
Vue向后臺傳數(shù)組數(shù)據(jù),springboot接收vue傳的數(shù)組數(shù)據(jù)實例
這篇文章主要介紹了Vue向后臺傳數(shù)組數(shù)據(jù),springboot接收vue傳的數(shù)組數(shù)據(jù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
關(guān)于vue3+echart5?遇到的坑?Cannot?read?properties?of?undefine
這篇文章主要介紹了vue3+echart5?遇到的坑?Cannot?read?properties?of?undefined?(reading?'type'),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04

