首頁 >web前端 >js教程 >在 Vue 裡面對 Axios 進行封裝

在 Vue 裡面對 Axios 進行封裝

Guanhui
Guanhui轉載
2020-05-20 11:03:222021瀏覽

在 Vue 裡面對 Axios 進行封裝

在前段項目中,請求api 以及請求方式進行封裝,該封裝為了簡單,更加好的管理後端所給的接口,請求代碼的複用性,代碼簡單化。

安裝axios

   $ npm install axios

建立目錄檔案

在src 中建立http 目錄

在http目錄中建立http.js 使用者所以請求的方式

在http 目錄中建立api.js 用於存放後端提供介面

在http 目錄中建立axios.js 使用者做axios 攔截器

在根目錄下方建立vue.config.js 使用者請求代理程式設定

接下裡就是程式碼

專案/scr/http/http.js 中程式碼

import axios from 'axios';
export default {
    /**
     * get 请求
     * @param url 接口路由
     * @param auth 是否需要带登录信息
     * @returns {AxiosPromise<any>}
     */
    get(url, auth = false) {
        if (auth) {
            return axios.get(url, {headers: {Authorization: &#39;Your back-end user authenticates information&#39;}});
        } else {
            return axios.get(url);
        }
    },
    /**
     * post 请求
     *
     * @param url 接口路由
     * @param data 接口参数
     * @param auth 是否需要带登录信息
     * @returns {AxiosPromise<any>}
     */
    post(url, data, auth = false) {
        if (auth) {
            return axios.post(url, data, {headers: {Authorization: &#39;Your back-end user authenticates information&#39;}});
        } else {
            return axios.post(url, data);
        }
    },
    /**
     * put请求
     * @param url 接口路由
     * @param data 接口参数
     * @param auth 是否需要带登录信息
     * @returns {AxiosPromise<any>}
     */
    put(url, data, auth = false) {
        if (auth) {
            return axios.put(url, data, {headers: {Authorization: &#39;Your back-end user authenticates information&#39;}});
        } else {
            return axios.put(url, data);
        }
    },
    /**
     * 删除
     * @param url 接口路由
     * @param auth 是否需要带登录信息
     * @returns {AxiosPromise}
     */
    del(url, auth = false) {
        if (auth) {
            return axios.delete(url, {headers: {Authorization: &#39;Your back-end user authenticates information&#39;}});
        } else {
            return axios.delete(url);
        }
    },
    /**
     * 上传文件
     * @param url 接口路由
     * @param file 接口文件
     * @param auth 是否需要带登录信息
     */
    uploader(url, file, auth = false) {
        let param = new FormData();
        param.append(&#39;file&#39;, file)
        if (auth) {
            return axios.post(url, param, {headers: {Authorization: &#39;Your back-end user authenticates information&#39;}})
        } else {
            return axios.post(url, param)
        }
    },
}

可以在專案/scr/http/ 下面建立一個檔案api 然後在裡根據專案模組建立介面檔案方便管理

專案/scr/http/api.js 程式碼

import Goods from &#39;./api/goods.js&#39;;
export default {
    // 首页
    Index: {
        index: &#39;/index/index&#39;
    },
    // 个人中心
    Home: {
        UserInfo: &#39;/user/info&#39;
    },
    // 当然也可以用文件方式进行管理
    Goods: Goods
}

專案/scr/http/api/goods.js 中程式碼

export default {
    GoodsShow: &#39;/goods/default&#39;
}

專案/scr/http/axios.js 中程式碼

import axios from &#39;axios&#39;;
// 请求拦截
axios.interceptors.request.use(config => {
    // 1. 这个位置就请求前最后的配置
  // 2. 当然你也可以在这个位置 加入你的后端需要的用户授权信息
  return config
}, error => {
    return Promise.reject(error)
})
// 响应拦截
axios.interceptors.response.use(response => {
  // 请求成功
  // 1. 根据自己项目需求定制自己的拦截
  // 2. 然后返回数据
  return response;
}, error => {
    // 请求失败
      if (error && error.response) {
            switch (error.response.status) {
                case 400:
                    // 对400错误您的处理\
                break
                case 401:
                    // 对 401 错误进行处理
                break
                default:
                // 如果以上都不是的处理
                return Promise.reject(error);
          }
    }
})

上面已經準備好了。那麼接下來就是專案/scr/min.js 中新增程式碼

專案/scr/min.js 中程式碼

import Vue from &#39;vue&#39;;
import App from &#39;./App.vue&#39;;
import api from &#39;./http/api&#39;;
import http from &#39;./http/http&#39;;
// axios 拦截器
import &#39;./http/axios&#39;
// 对后端接口 进行全局注册
Vue.prototype.$api = api;
// 对请求方式 进行全局注册
Vue.prototype.$http = http;
那么接下来就是使用了
项目 /src/views/index/index.vue 中我们对他进行使用
<template>
     <div>
     </div>
 </template>
<script>
  export default {
        name: "Index",
        mounted() {
            this.handle()
        },
        methods: {
            handle(){
                // 当然如果你需要带登录信息去请求这个接口 可以在 路由后面跟上 true 或者 false 来决定是否在请求的时候带登录信息
                // 我们这样进行封装 就对一个 请求封装好了。
               this.$http.get(this.$api.Index.index,true).then((result) => {
               })
            }
        }
    }
</script>
<style scoped>
</style>

接下來是代理程式設定

專案/vue .config.js 程式碼

// 后端请求地址 注意[他会根据你环境的不同从而获取的 env 文件不同]
const target = process.env.APP_API_URL;
module.exports = {
  devServer: {
    // 所有的接口请求代理
  proxy: {
      &#39;/api&#39;: {
        target: target,
        changeOrigin: true,
        ws: true,
        pathRewrite: {
              &#39;^api&#39;: &#39;&#39;
        }
      }
    }
  }
}

推薦教學:《PHP教學》《JS教學

以上是在 Vue 裡面對 Axios 進行封裝的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:articles。如有侵權,請聯絡admin@php.cn刪除