vue +axios+promise封裝

import axios? ? ? ? ? ? ? ? from 'axios'

import {Message}from 'element-ui'

import router from '../router/permission'

import Vuefrom 'vue'

import VueCookiesfrom 'vue-cookies'

const moment =require('moment');

const Base64 =require('js-base64').Base64;

// loading框設(shè)置局部刷新游岳,且所有請(qǐng)求完成后關(guān)閉loading框

var loading;

function startLoading() {

loading = Vue.prototype.$loading({

lock:true,

text:"Loading...",

target:document.querySelector('.loading-area')//設(shè)置加載動(dòng)畫區(qū)域

? });

}

function endLoading() {

loading.close();

}

// 聲明一個(gè)對(duì)象用于存儲(chǔ)請(qǐng)求個(gè)數(shù)

var needLoadingRequestCount =0;

function showFullScreenLoading() {

if (needLoadingRequestCount ===0) {

startLoading();

}

needLoadingRequestCount++;

};

function tryHideFullScreenLoading() {

if (needLoadingRequestCount <=0)return;

needLoadingRequestCount--;

if (needLoadingRequestCount ===0) {

endLoading();

}

};

// 請(qǐng)求攔截

axios.interceptors.request.use(config => {

let token ="";

showFullScreenLoading();

if(VueCookies.isKey('userinfo')) {

const USERINFO = VueCookies.get('userinfo');

if(config.method =='get') {

token =Base64.encode(USERINFO.token +'|' +moment().utc().format('YYY-MM-DD HH:mm:ss' +'|' +JSON.stringify(config.params)));

config.params.hospitalId =USERINFO.hospitalId;

}else {

token =Base64.encode(USERINFO.token +'|' +moment().utc().format('YYY-MM-DD HH:mm:ss' +'|' +JSON.stringify(config.data)));

config.data.hospitalId =USERINFO.hospitalId;

}

let TOKENSTART =token.slice(0,10),

TOKENEND =token.slice(10);

token =TOKENEND +TOKENSTART;

config.headers['token'] =token;

}

return config;

}, err => {

tryHideFullScreenLoading();

Message.error({message:'請(qǐng)求超時(shí)!' });

return Promise.resolve(err);

})

// 響應(yīng)攔截

axios.interceptors.response.use(res => {

tryHideFullScreenLoading();

switch(res.data.code) {

case 200:

return res.data.result;

case 401:

router.push('/login');

VueCookies.remove('userinfo');

return Promise.reject(res);

case 201:

Message.error({message: res.data.msg });

return Promise.reject(res);

default :

return Promise.reject(res);

}

}, err => {

tryHideFullScreenLoading();

if(!err.response.status) {

return false;

}

switch(err.response.status) {

case 504:

Message.error({message:'服務(wù)器被吃了⊙﹏⊙∥' });

break;

case 404:

Message.error({message:'服務(wù)器被吃了⊙﹏⊙∥' });

break;

case 403:

Message.error({message:'權(quán)限不足,請(qǐng)聯(lián)系管理員!' });

break;

default:

return Promise.reject(err);

}

})

axios.defaults.timeout =300000;// 請(qǐng)求超時(shí)5fen

export const postJsonRequest = (url, params) => {

return axios({

method:'post',

url: url,

data: params,

headers: {

'Content-Type':'application/json',

},

});

}

export const postRequest = (url, params) => {

return axios({

method:'post',

url: url,

data: params,

transformRequest: [function (data) {

let ret =''

? ? ? for (let it in data) {

ret +=encodeURIComponent(it) +'=' +encodeURIComponent(data[it]) +'&'

? ? ? }

return ret

? ? }],

headers: {

'Content-Type':'application/x-www-form-urlencoded'

? ? }

});

}

export const getRequest = (url, data ='') => {

return axios({

method:'get',

params: data,

url: url,

});

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末糊啡,一起剝皮案震驚了整個(gè)濱河市神年,隨后出現(xiàn)的幾起案子全蝶,更是在濱河造成了極大的恐慌,老刑警劉巖敢靡,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件救军,死亡現(xiàn)場(chǎng)離奇詭異嫉髓,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)谎仲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門浙垫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人郑诺,你說(shuō)我怎么就攤上這事夹姥。” “怎么了辙诞?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵辙售,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我飞涂,道長(zhǎng)旦部,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任较店,我火速辦了婚禮士八,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘梁呈。我一直安慰自己婚度,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布官卡。 她就那樣靜靜地躺著蝗茁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪味抖。 梳的紋絲不亂的頭發(fā)上评甜,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音仔涩,去河邊找鬼忍坷。 笑死,一個(gè)胖子當(dāng)著我的面吹牛熔脂,可吹牛的內(nèi)容都是我干的佩研。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼霞揉,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼旬薯!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起适秩,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤绊序,失蹤者是張志新(化名)和其女友劉穎硕舆,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體骤公,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡抚官,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了阶捆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片凌节。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖洒试,靈堂內(nèi)的尸體忽然破棺而出倍奢,到底是詐尸還是另有隱情,我是刑警寧澤垒棋,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布卒煞,位于F島的核電站,受9級(jí)特大地震影響叼架,放射性物質(zhì)發(fā)生泄漏跷坝。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一碉碉、第九天 我趴在偏房一處隱蔽的房頂上張望柴钻。 院中可真熱鬧,春花似錦垢粮、人聲如沸贴届。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)毫蚓。三九已至,卻和暖如春昔善,著一層夾襖步出監(jiān)牢的瞬間元潘,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工君仆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留翩概,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓返咱,卻偏偏與公主長(zhǎng)得像钥庇,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子咖摹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

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