zoukankan      html  css  js  c++  java
  • vue axios的封装

    在根目录上创建一个vue.config.js文件

    const path = require("path");
    const resolve = function(dir) {
        return path.join(__dirname, dir);
    };
    module.exports = {
        publicPath: "./",
        outputDir: "dist",
        assetsDir: "static",
        lintOnSave: false, // 是否开启eslint保存检测
        productionSourceMap: false, // 是否在构建生产包时生成sourcdeMap
        chainWebpack: config => {
            config.resolve.alias
                .set("@", resolve("src"))
                .set("@", resolve("src/views"))
                .set("@", resolve("src/components"))
                .set("@", resolve("src/common"))
                .set("@", resolve("src/utils"))
                .set("@", resolve("src/service")); /* 别名配置 */
            config.optimization.runtimeChunk("single");
        },
        devServer: {
            // host: "localhost",
            /* 本地ip地址 */
            host: "localhost",
            port: "10000",
            hot: true,
            /* 自动打开浏览器 */
            open: true,
            overlay: {
                warning: false,
                error: true
            },
            /* 跨域代理 */
            proxy: {
                "/item": {
                    /* 目标代理服务器地址 */
                    target: "http://localhost:80", //localhost:80/api/item/category/list
                    /* 允许跨域 */
                    changeOrigin: true,
                    ws: true,
                    pathRewrite: {
                        "^/item": ""
                    }
                }
            }
        }
    };
    

      

     在api.js里面配置

    import Vue from 'vue'
    import modules from '@/api'
    
    const api = {
    //实例化axios  用$api代替
      install(Vue) {
        Vue.prototype.$api = modules
        Vue.$api = modules
      },
      $api: modules
    }
    
    Vue.use(api)
    

      在axios.js

    import axios from 'axios'
    import printLog from './log'
    
    //创建axios实例
    const fetch = axios.create({
      baseURL:'/api',
      timeout: 15000
    })
    
    // 修改 axios 实例默认配置
    fetch.defaults.headers.post['Content-Type'] = 'application/json'
    fetch.defaults.headers.put['Content-Type'] = 'application/json'
    fetch.defaults.headers.patch['Content-Type'] = 'application/json'
    
    //request拦截器
    fetch.interceptors.request.use(
      config =>{
        if (config.method === 'get') {
          if (config.params === undefined) {
            config.params = {}
          }
          config.params = {
            ...config.params,
            ...(config.params.filter
              ? {
              filter: JSON.stringify(config.params.filter)
              }
              :{})
          }
        }
        printLog({ config })
        return config
      },
      error =>{
        //网络没建立成功
       window.console.error(error)
        return Promise.reject(error)
      }
    )
    
    //response拦截器
    fetch.interceptors.response.use(
      response =>{
        printLog({ response })
        if (response.status === 200) {
          return checkResponseCode(response)
        } else {
          //window.console.log(response)
        }
      },
      error => {
        //后台服务异常  404 504 请求超时等
        //window.console.err(error, error.response, error.message)
        return Promise.reject(error.response)
      }
    )
    
    const checkResponseCode = response => {
     switch (response.data.code) {
       case 0:
         return Promise.reject(response.data)
    
       case 404:
         return Promise.reject(response.data)
     }
    }
    
    export default fetch
    

      request.js

    import axios from 'axios'
    //创建axios实例
    const service = axios.create({
      baseURL: '/api',
      timeout: 15000 //请求超出时间
    })
    
    //请求拦截
    service.interceptors.request.use(
      config => {
        return config
      },
      error => {
        return Promise.reject(error)
      }
    )
    
    //响应拦截
    service.interceptors.response.use(
      response=>{
        const { code, msg, data } = response.data
        if (code === 0) {
          return data
        } else {
          return promptError(code,msg,response.data)
        }
      },
      error => {
        const { status, statusText, data } = error.response
        return promptError(status, data.msg || statusText, error.response)
    
      }
    )
    
    /**
     * 提示错误
     * @param CODE 错误码
     * @param MSG 错误提示
     * @param REJECT reject 内容
     * @returns {Promise<never>}
     */
    const promptError = (CODE, MSG, REJECT) => {
      //错误描述
      return Promise.reject(REJECT)
    }
    export { service as axios}

    在api文件夹下的index.js

    const files = require.context('.', false, /.js$/)
    let modules = {}
    
    files.keys().forEach(key => {
      if (key === './index.js') return
      modules = { ...modules, ...files(key) }
    })
    
    export default modules
    

     在user.js封装统一的请求 

    import { axios } from '@/utils/axios/request'
    
    //登录
    export const login = data => {
      return axios.post('/v1/user/login', data)
    }
      //如果配置了 pathRewrite 需要在路径之前加上重写的
      /*
    例
     pathRewrite:{
               '^/api': ''
            }
    
    这里的请求就需要写成
    export const login = data => {
      return axios.post('/api/v1/user/login', data)
    }
    */
    //注册
    export const register = data => {
      return axios.post('/v1/user/register', data)
    }
    
    //提交信息采集表
    export const enrollment = data => {
      return axios.post('/v1/enrollment/post', data)
    }
    

      log.js

    export default ({ config, response }) => {
      const debug = true
      if (debug) {
        // 请求
        if (config) {
          window.console.groupCollapsed(`%c[${config.method}]`, 'color:#ffb400', config.baseURL + config.url)
          // console.log('%c[Content-Type]', 'color:#ffb400', config.method, config.headers[config.method]['Content-Type'])
          // console.log('%c[X-Access-Token]', 'color:#ffb400', config.headers['X-Access-Token'])
          if (config.method === 'get' || config.method === 'delete') {
            window.console.log('%c[params]', 'color:#ffb400', config.params)
          } else {
            window.console.log('%c[data]', 'color:#ffb400', config.data)
          }
          window.console.dir(config)
          window.console.groupEnd()
        }
    
        // 响应
        if (response) {
          if (response.data.code === 0) {
          window.console.groupCollapsed(`%c[响应成功]`, 'color:#27ae60', response.config.url)
          window.console.log('%c[data]', 'color:#ffb400', response.data.data)
          window.console.dir(response.data)
          window.console.groupEnd()
          } else {
          window.console.group(`%c[响应错误]`, 'color:#e1514c', response.config.url)
          window.console.log('%c[code]', 'color:#e1514c', response.data.code)
          window.console.log('%c[msg]', 'color:#e1514c', response.data.msg)
          window.console.groupEnd()
          }
        }
      }
    }
    

      

    非常感谢https://me.csdn.net/weixin_43893437对我的帮助。

  • 相关阅读:
    信息安全系统设计基础第八周期中复习总结
    layui下各种富文本的冲突情况
    TP3.2+find_set_in 以及 find_set_in和like的区别
    tp5+linux+apache php7.1.30环境下,上传图片报错:mkdir():permission denied
    一次基于老古董thinkPHP3.1的修改尝试
    微信网页开发 thinkphp5.0的try-catch和重定向
    CentOS 7.2下服务器配置(linux+apache+php+mysql)
    微信小程序踩坑(不定时更新)
    PHP 定时自动执行代码
    PHP TP5 文章评论+积分+签到
  • 原文地址:https://www.cnblogs.com/yscec/p/12114011.html
Copyright © 2011-2022 走看看