zoukankan      html  css  js  c++  java
  • 在vue项目中的axios使用配置记录

    默认vue项目中已经安装axios,基于element-ui开发,主要记录配置的相关。

    • axiosConfig.js
    import Vue from 'vue'
    import axios from 'axios'
    import qs from 'qs'
    import { Message, Loading } from 'element-ui'
    // 响应时间
    axios.defaults.timeout = 5 * 1000
    // 配置cookie
    // axios.defaults.withCredentials = true
    // 配置请求头
    axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'
    // 静态资源
    Vue.prototype.$static = ''
    
    // 配置接口地址
    axios.defaults.baseURL = ''
    var loadingInstance
    // POST传参序列化(添加请求拦截器)
    axios.interceptors.request.use(
      config => {
        loadingInstance = Loading.service({
          lock: true,
          text: '数据加载中,请稍后...',
          spinner: 'el-icon-loading',
          background: 'rgba(0, 0, 0, 0.7)'
        })
        if (config.method === 'post') {
          config.data = qs.stringify(config.data)
        }
        return config
      },
      err => {
        loadingInstance.close()
        Message.error('请求错误')
        return Promise.reject(err)
      }
    )
    // 返回状态判断(添加响应拦截器)
    axios.interceptors.response.use(
      res => {
        if (res.data.code === 200) {
          loadingInstance.close()
          return res
        } else {
          loadingInstance.close()
          Message.error(res.data.msg)
        }
      },
      err => {
        loadingInstance.close()
        Message.error('请求失败,请稍后再试')
        return Promise.reject(err)
      }
    )
    // 发送请求
    export function fetchPost (url, params) {
      return new Promise((resolve, reject) => {
        axios
          .post(url, params)
          .then(
            res => {
              resolve(res.data)
            },
            err => {
              reject(err.data)
            }
          )
          .catch(err => {
            reject(err.data)
          })
      })
    }
    export function fetchGet (url, params) {
      return new Promise((resolve, reject) => {
        axios
          .get(url, {
            params: params
          })
          .then(res => {
            resolve(res.data)
          })
          .catch(err => {
            reject(err.data)
          })
      })
    }

    export default {
    // 获取后台接口
    getGoodsInfo(data) {
    return fetchPost('/goods/info',data);
    }
    }

    main.js 配置

    import { fetchGet, fetchPost} from './api/axiosConfig'
    Vue.prototype.$get = fetchGet
    Vue.prototype.$post = fetchPost

    组件内部的调用

    先引入 封装的js文件

      methods: {
        ...mapMutations(["initGoods"]),
        getGoodsInfo() {
          let params = {
            goods_id: this.getGoodsId
          };
    
          api
            .getGoodsInfo(params)
            .then(res => {
              this.goodsInfo = res.data;
            })
            .catch(() => {});
        }
      }
  • 相关阅读:
    hdu1828线段树(两次扫描+离散化)
    hdu1542线段树(扫描线+离散化)
    二分思想
    hdu2871线段树区间更新
    git初体验
    python笔记-模块
    python笔记-动态类型
    AWS上创建EKS(K8S)集群
    Akamai CDN刷新(通过Akamai cli 自动刷新)
    创建Akamai cdn api授权
  • 原文地址:https://www.cnblogs.com/mica/p/10795242.html
Copyright © 2011-2022 走看看