欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue中axios的使用與封裝

 更新時(shí)間:2019年03月20日 16:37:26   作者:''''王''''  
這篇文章主要介紹了vue中axios的使用與封裝,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

分享下我自己的axios封裝
axios是個(gè)很好用的插件,都是一些params對(duì)象,所以很方便做一些統(tǒng)一處理

當(dāng)然首先是npm安裝axios 很簡(jiǎn)單$ npm install axios --save
在src下新建文件夾 service / index.js

接著上代碼

import axios from 'axios';
import { Toast} from 'mint-ui';// 我用的mint的框架來(lái)彈出我的錯(cuò)誤返回 大家可以用別的提示
import router from '../router'

// 默認(rèn)超時(shí)設(shè)置
axios.defaults.timeout = 50000;

// 相對(duì)路徑設(shè)置
axios.defaults.baseURL ='';

//http request 攔截器
axios.interceptors.request.use(
 config => {
  // 獲取token
  const token = localStorage.getItem('cc_token');
  // 設(shè)置參數(shù)格式
  if(!config.headers['Content-Type']){
   config.headers = {
    'Content-Type':'application/json',
   };
  }
  // 添加token到headers
  if(token){
   config.headers.token = token
  }
  // 鑒權(quán)參數(shù)設(shè)置
  if(config.method === 'get'){
    //get請(qǐng)求下 參數(shù)在params中,其他請(qǐng)求在data中
   config.params = config.params || {};
   let json = JSON.parse(JSON.stringify(config.params));
   //一些參數(shù)處理
  }else{
   config.data = config.data || {};
   //一些參數(shù)處理
  }
  return config;
 },
 err => {
  return Promise.reject(err);
 }
);

以上請(qǐng)求之前的一些處理就完成了
下面是獲得返回的一些處理

//http response 攔截器
axios.interceptors.response.use(
 response => {
  //一些統(tǒng)一code的返回處理
  if(response.data.code === 501){
   // 登錄驗(yàn)證
   //做了個(gè)示例跳轉(zhuǎn)項(xiàng)目中登錄,并記錄下相對(duì)路徑
   router.push({
    name:'login',//從哪個(gè)頁(yè)面跳轉(zhuǎn)
    query:{
     retUrl:window.location.href.split('#')[1] || '',
     is_new_user_url:1
    }
   })
  }
  return response;
 },
 error => {
  return Promise.reject(error)
 }
);

接著把所有請(qǐng)求類型都做下簡(jiǎn)單封裝

/**
 * 封裝get方法
 * @param url
 * @param params
 * @returns {Promise}
 */
export function fetch(url,params={}){
 return new Promise((resolve,reject) => {
  axios.get(url,{
   params:params
  })
   .then(response => {
    if(response.data.code === 200){
    //返回成功處理 這里傳的啥 后續(xù)調(diào)用的時(shí)候 res就是啥
     resolve(response.data.data);//我們后臺(tái)所有數(shù)據(jù)都是放在返回的data里所以這里統(tǒng)一處理了
    }else{
    //錯(cuò)誤處理
     Toast(response.data.msg)
    }
   })
   .catch(err => {
    reject(err);
    let message = '請(qǐng)求失?。≌?qǐng)檢查網(wǎng)絡(luò)';
    //錯(cuò)誤返回
    if(err.response)message=err.response.data.message;
    Toast(message)
   })
 })
}

/**
 * 封裝post請(qǐng)求
 * @param url
 * @param data
 * @returns {Promise}
 */

export function post(url,data = {}){
 return new Promise((resolve,reject) => {
  axios.post(url,data)
   .then(response => {
    if(response.data.code === 200){
     resolve(response.data.data);
    }else{
     Toast(response.data.msg)
    }
   },err => {
    reject(err);
    let message = '請(qǐng)求失??!請(qǐng)檢查網(wǎng)絡(luò)';
    if(err.response)message=err.response.data.message;
    Toast(message)
   })
 })
}

/**
 * 封裝patch請(qǐng)求
 * @param url
 * @param data
 * @returns {Promise}
 */

export function patch(url,data = {}){
 return new Promise((resolve,reject) => {
  axios.patch(url,data)
   .then(response => {
    if(response.data.code === 200){
     resolve(response.data.data);
    }else{
     Toast(response.data.msg)
    }
   },err => {
    reject(err);
    let message = '請(qǐng)求失?。≌?qǐng)檢查網(wǎng)絡(luò)';
    if(err.response)message=err.response.data.message;
    Toast(message)
   })
 })
}

/**
 * 封裝put請(qǐng)求
 * @param url
 * @param data
 * @returns {Promise}
 */

export function put(url,data = {}){
 return new Promise((resolve,reject) => {
  axios.put(url,data)
   .then(response => {
    if(response.data.code === 200){
     resolve(response.data.data);
    }else{
     Toast(response.data.msg)
    }
   },err => {
    reject(err);
    let message = '請(qǐng)求失?。≌?qǐng)檢查網(wǎng)絡(luò)';
    if(err.response)message=err.response.data.message;
    Toast(message)
   })
 })
}

export function del(url,data = {}){
 return new Promise((resolve,reject) => {
  axios.delete(url,data)
   .then(response => {
    if(response.data.code === 200){
     resolve(response.data.data);
    }else{
     Toast(response.data.msg)
    }
   },err => {
    reject(err);
    let message = '請(qǐng)求失?。≌?qǐng)檢查網(wǎng)絡(luò)';
    if(err.response)message=err.response.data.message;
    Toast(message)
   })
 })
}

好了 主要的文件編輯好 然后在service中新建api.js文件并引入對(duì)應(yīng)組件方法

import Vue from 'vue';
import {post,fetch,patch,put,del,upload,ret2} from './index'
Vue.prototype.$post=post;
Vue.prototype.$fetch=fetch;
Vue.prototype.$patch=patch;
Vue.prototype.$put=put;
Vue.prototype.$del=del;

接著就可以開(kāi)始寫各個(gè)API方法了

//也可以不需要
const _baseUrl=process.env.API_URL;//這里我在項(xiàng)目配置文件里面設(shè)置了相對(duì)路徑
//登錄方法
const loginURL = `${_baseUrl}api/admin/login`;
export const loginApi = function(json) {
 return Vue.prototype.$post(loginURL,{"username":json.username,"passwd":json.password})
};
//修改賬號(hào)信息RESTful
const editAdminUrl = `${_baseUrl}api/admin/user/info`;
export const editAdminListApi = function (id,json) {
 return Vue.prototype.$put(`${editAdminUrl}/${id}`,json)
};
//等等...

最后是使用,非常簡(jiǎn)單方便,在vue文件中引入并使用

import { loginApi ,editAdminListApi } from "../../service/api";
  export default {
    methods:{
      //登錄
      login(){
        let json = {
          userName:'xx',
          password:'xx'
        }
        loginApi().then(res=>{
          console.log(res)
        })
      },
      // RESTful 修改信息
      editAdminList(){
        let id = 1;
        let json = {name:11};
        editAdminListApi(id,json).then(res=>{
          console.log(res)
        })
      }
    }
  }

使用方便簡(jiǎn)潔。

以上所述是小編給大家介紹的vue中axios的使用與封裝詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 手把手帶你安裝vue-cli并創(chuàng)建第一個(gè)vue-cli應(yīng)用程序

    手把手帶你安裝vue-cli并創(chuàng)建第一個(gè)vue-cli應(yīng)用程序

    vue-cli這個(gè)構(gòu)建工具大大降低了webpack的使用難度,支持熱更新,有webpack-dev-server的支持,相當(dāng)于啟動(dòng)了一個(gè)請(qǐng)求服務(wù)器,給你搭建了一個(gè)測(cè)試環(huán)境,下面這篇文章主要給大家介紹了關(guān)于安裝vue-cli并創(chuàng)建第一個(gè)vue-cli應(yīng)用程序的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • Vue之修改數(shù)據(jù)頁(yè)面不更新的問(wèn)題

    Vue之修改數(shù)據(jù)頁(yè)面不更新的問(wèn)題

    這篇文章主要介紹了Vue之修改數(shù)據(jù)頁(yè)面不更新的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Vue computed實(shí)現(xiàn)原理深入講解

    Vue computed實(shí)現(xiàn)原理深入講解

    computed又被稱作計(jì)算屬性,用于動(dòng)態(tài)的根據(jù)某個(gè)值或某些值的變化,來(lái)產(chǎn)生對(duì)應(yīng)的變化,computed具有緩存性,當(dāng)無(wú)關(guān)值變化時(shí),不會(huì)引起computed聲明值的變化。產(chǎn)生一個(gè)新的變量并掛載到vue實(shí)例上去
    2022-10-10
  • vue實(shí)現(xiàn)井字棋游戲

    vue實(shí)現(xiàn)井字棋游戲

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)井字棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏

    Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)動(dòng)態(tài)控制表格列的顯示和隱藏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue3獲取子組件的DOM元素的方法總結(jié)

    vue3獲取子組件的DOM元素的方法總結(jié)

    在 Vue 3 中,訪問(wèn)子組件的 DOM 元素是一個(gè)常見(jiàn)的需求,本文將介紹如何在 Vue 3 中使用不同的方法來(lái)獲取子組件的 DOM 元素,需要的朋友可以參考下
    2023-08-08
  • uni-app 使用編輯器創(chuàng)建vue3 項(xiàng)目并且運(yùn)行的操作方法

    uni-app 使用編輯器創(chuàng)建vue3 項(xiàng)目并且運(yùn)行的操作方法

    這篇文章主要介紹了uni-app 使用編輯器創(chuàng)建vue3 項(xiàng)目并且運(yùn)行的操作方法,目前uniapp 創(chuàng)建的vue3支持 vue3.0 -- 3.2版本 也就是說(shuō)setup語(yǔ)法糖也是支持的,需要的朋友可以參考下
    2023-01-01
  • Vue?$event作為參數(shù)傳遞使用demo

    Vue?$event作為參數(shù)傳遞使用demo

    這篇文章主要介紹了Vue?$event作為參數(shù)傳遞使用demo詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • ant design 日期格式化的實(shí)現(xiàn)

    ant design 日期格式化的實(shí)現(xiàn)

    這篇文章主要介紹了ant design 日期格式化的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • vue+ElementUI實(shí)現(xiàn)訂單頁(yè)動(dòng)態(tài)添加產(chǎn)品數(shù)據(jù)效果實(shí)例代碼

    vue+ElementUI實(shí)現(xiàn)訂單頁(yè)動(dòng)態(tài)添加產(chǎn)品數(shù)據(jù)效果實(shí)例代碼

    本篇文章主要介紹了vue+ElementUI實(shí)現(xiàn)訂單頁(yè)動(dòng)態(tài)添加產(chǎn)品效果實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評(píng)論