vue封装axios

1.下载axios

npm install axios

 2.创建request.js文件

目录:src/utils/request.js

//request.js文件
import axios from "axios";

//创建实例 这里设置baseURL是为了统一接口在vue.config.js里面做代理
const http = axios.create({
    baseURL: '/api', 
    timeout: 1000, 
    headers: {
        'Content-Type': 'application/json'
    }
});


// 添加请求拦截器
http.interceptors.request.use(function (config) {
    // 在发送请求之前做些什么 一般都在请求之前加上token在我们的Authorization里面
    return config;
  }, function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  });

// 添加响应拦截器
http.interceptors.response.use(function (response) {
    // 对响应数据做点什么  响应拦截一般都是对响应数据进行一个返回可以返回response.data具体情况看你们的数据格式
    return response;
  }, function (error) {
    // 对响应错误做点什么
    return Promise.reject(error);
  });


export default http

3.接口封装

为了接口统一管理我们一般都是在src/api文件夹下面创建接口文件

例如:exampleApi.js

import http from "@/utils/request";
import qs from 'qs'

// 实例POST接口
export function examplePost (data) {
    return http.request({
        url: '/api/examplePost',
        method: 'POST',
        data
    })
}

// 实例GET接口
export function examplePostGet(data) {
    return http.request({
        url: '/api/examplePostGet?'+qs.stringify(data),
        method: 'GET',
    })
}


其中的qs模块就是对请求参数的一个格式化 它可以将我们的参数自动拼接到url中

例如:

参数
data:{
name:'sanmu',
age:13,
sex:'男',
clazz:'三年级二班'
}

当你使用
str = qs.stringify(data)
返回的数据就是 str 就是 name=sanmu&age=13&sex=男&clazz=三年级二班
这样

4.页面使用

//哪个页面使用哪个页面引入
<script>
import { examplePost,examplePostGet } from "@/api/exampleApi"
export default {
  methods: {
    textFn() {
      examplePost({ text: '测试参数' }).then(res => {
        console.log(res);
      })
    }
  },
}

</script>

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zWoods

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值