vue中使用axios的多種方式

文檔: https://www.kancloud.cn/yunye/axios/234845
官網(wǎng): https://www.axios.com/
gitHub: https://github.com/axios/axios

axios

axios 是一個基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端

它本身具有以下特征:

  • 從瀏覽器中創(chuàng)建 XMLHttpRequest
  • 從 node.js 發(fā)出 http 請求
  • 支持 Promise API
  • 攔截請求和響應
  • 轉換請求和響應數(shù)據(jù)
  • 取消請求
  • 自動轉換JSON數(shù)據(jù)
  • 客戶端支持防止 CSRF/XSRF

安裝

安裝其他插件的時候,可以直接在 main.js 中引入并 Vue.use()缀磕,但是 axios 并不能 use橙凳,只能每個需要發(fā)送請求的組件中即時引入

為了解決這個問題遇革,有兩種開發(fā)思路闹丐,一是在引入 axios 之后烘嘱,修改原型鏈鹦付,二是結合 Vuex尚粘,封裝一個 aciton

使用npm

npm install axios

使用cdn:

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

解決post方法使用application/x-www-form-urlencoded格式編碼數(shù)據(jù)

  1. 設置 headers:{ 'Content-type': 'application/x-www-form-urlencoded'}
axios.post('url',data,{headers:{ 'Content-type': 'application/x-www-form-urlencoded'}})

// 不想在每次請求都設置的話,可以集中設置下
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded; charset=UTF-8';

  1. 僅僅這樣并沒有達到想要的效果敲长,post的body主體中還是{"age":10}這樣的格
    式郎嫁,并不是我們想要的query參數(shù)互捌。引入Qs,這個庫是axios里面包含的行剂,不需要再下載了
    import qs from 'qs'
    var data = qs.stringify({"name":"xie"});
    axios.post('url',data).then()
    

axios默認是不讓ajax請求頭部攜帶cookie的

axios 解決跨域cookie丟失問題

設置 axios.defaults.withCredentials = true 即可

示例代碼:

                axios.defaults.withCredentials = true;
                var param = new URLSearchParams();
                param.append("vCode",vcode);
                axios.post('http://localhost',param)
                    .then(function(res) {
                        var rs=res.data;
                        console.log(rs.data);
                    })
                    .catch(function(err) {
                        console.log(err);
                    });

配合vue

Vue 原本有一個官方推薦的 ajax 插件 vue-resource秕噪,但是自從 Vue 更新到 2.0 之后,官方就不再更新 vue-resource

目前主流的 Vue 項目厚宰,都選擇 axios 來完成 ajax 請求

之前一直使用的是 vue-resource插件腌巾,在主入口文件引入import VueResource from 'vue-resource'之后,直接使用Vue.use(VueResource)之后即可將該插件全局引用了铲觉;

初用axios時澈蝙,無腦的按照上面的步驟進行全局引用,結果當時是慘慘的撵幽。
看了看文檔灯荧,Axios 是一個基于 promise 的 HTTP 庫

axios并沒有install 方法,所以是不能使用vue.use()方法的盐杂。
那么難道每個文件都要來引用一次逗载?解決方法有很多種:
1.結合 vue-axios使用

  1. axios 改寫為 Vue 的原型屬性
    3.結合 Vuex的action

結合 vue-axios使用

vue-axios

用于將axios集成到Vuejs的小包裝器

github: https://github.com/axios/axios

安裝: npm install --save axios vue-axios

vue-axios是按照vue插件的方式去寫的。那么結合vue-axios链烈,就可以去使用vue.use方法了

首先在主入口文件main.js中引用

import axios from 'axios'
import VueAxios from 'vue-axios'

Vue.use(VueAxios,axios);

之后就可以使用了厉斟,在組件文件中的methods里去使用了

getNewsList(){
      this.axios.get('api/getNewsList').then((response)=>{
        this.newsList=response.data.data;
      }).catch((response)=>{
        console.log(response);
      })


    },

方法2: axios 改寫為 Vue 的原型屬性

首先在主入口文件main.js中引用,之后掛在vue的原型鏈上

import axios from 'axios'
Vue.prototype.$axios= axios

在組件中使用

this.$axios.get('api/getNewsList').then((response)=>{
        this.newsList=response.data.data;
      }).catch((response)=>{
        console.log(response);
      })

方法3:結合vuex

在vuex在封裝一層

封裝 axios

import axios from 'axios'
import { Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'

// 創(chuàng)建axios實例
const service = axios.create({
  baseURL: process.env.BASE_API, // api的base_url
  timeout: 5000 // 請求超時時間
})

// request攔截器
service.interceptors.request.use(config => {
  // Do something before request is sent
  if (store.getters.token) {
    config.headers['X-Token'] = getToken() // 讓每個請求攜帶token--['X-Token']為自定義key 請根據(jù)實際情況自行修改
  }
  return config
}, error => {
  // Do something with request error
  console.log(error) // for debug
  Promise.reject(error)
})

// respone攔截器
service.interceptors.response.use(
  response => response,
  /**
  * 下面的注釋為通過response自定義code來標示請求狀態(tài)强衡,當code返回如下情況為權限有問題擦秽,登出并返回到登錄頁
  * 如通過xmlhttprequest 狀態(tài)碼標識 邏輯可寫在下面error中
  */
  //  const res = response.data;
  //     if (res.code !== 20000) {
  //       Message({
  //         message: res.message,
  //         type: 'error',
  //         duration: 5 * 1000
  //       });
  //       // 50008:非法的token; 50012:其他客戶端登錄了;  50014:Token 過期了;
  //       if (res.code === 50008 || res.code === 50012 || res.code === 50014) {
  //         MessageBox.confirm('你已被登出,可以取消繼續(xù)留在該頁面漩勤,或者重新登錄', '確定登出', {
  //           confirmButtonText: '重新登錄',
  //           cancelButtonText: '取消',
  //           type: 'warning'
  //         }).then(() => {
  //           store.dispatch('FedLogOut').then(() => {
  //             location.reload();// 為了重新實例化vue-router對象 避免bug
  //           });
  //         })
  //       }
  //       return Promise.reject('error');
  //     } else {
  //       return response.data;
  //     }
  error => {
    console.log('err' + error)// for debug
    Message({
      message: error.message,
      type: 'error',
      duration: 5 * 1000
    })
    return Promise.reject(error)
  })

export default service

import request from '@/utils/request'

//使用
export function getInfo(params) {
  return request({
    url: '/user/info',
    method: 'get',
    params
  });
}
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末感挥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子越败,更是在濱河造成了極大的恐慌触幼,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件眉尸,死亡現(xiàn)場離奇詭異域蜗,居然都是意外死亡,警方通過查閱死者的電腦和手機噪猾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門霉祸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人袱蜡,你說我怎么就攤上這事丝蹭。” “怎么了坪蚁?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵奔穿,是天一觀的道長镜沽。 經(jīng)常有香客問我,道長贱田,這世上最難降的妖魔是什么缅茉? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮男摧,結果婚禮上蔬墩,老公的妹妹穿的比我還像新娘。我一直安慰自己耗拓,他們只是感情好拇颅,可當我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著乔询,像睡著了一般樟插。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上竿刁,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天黄锤,我揣著相機與錄音,去河邊找鬼们妥。 笑死猜扮,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的监婶。 我是一名探鬼主播,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼齿桃,長吁一口氣:“原來是場噩夢啊……” “哼惑惶!你這毒婦竟也來了?” 一聲冷哼從身側響起短纵,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤带污,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后香到,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鱼冀,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年悠就,在試婚紗的時候發(fā)現(xiàn)自己被綠了千绪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡梗脾,死狀恐怖荸型,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情炸茧,我是刑警寧澤瑞妇,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布稿静,位于F島的核電站,受9級特大地震影響辕狰,放射性物質發(fā)生泄漏改备。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一蔓倍、第九天 我趴在偏房一處隱蔽的房頂上張望绍妨。 院中可真熱鬧,春花似錦柬脸、人聲如沸他去。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽灾测。三九已至,卻和暖如春垦巴,著一層夾襖步出監(jiān)牢的瞬間媳搪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工骤宣, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留秦爆,地道東北人。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓憔披,卻偏偏與公主長得像等限,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子芬膝,可洞房花燭夜當晚...
    茶點故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內(nèi)容