Vue封装接口思路(包括请求(响应拦截器))

一、Vue封装接口思路


 1. 通用的ajax工具函数层(所有的ajax都用这个函数)
		服务器地址
		请求超时 
		请求拦截
		响应拦截
 2. ajax函数层
		分模块封装
 3. 组件层
		引用
		使用

二、封装接口实现

2-1、通用的ajax工具函数层

utills文件夹下面的request.js

// 1.ajax工具函数层
import Axios from "axios";

// 2.服务器地址
const request = Axios.create({
    baseURL:'http://localhost:3000/api'
})
// 3.超时时间、
request.defaults.timeout = 30000

// 4.请求拦截器
request.interceptors.request.use((config)=>{
    return config
},(err)=>{
    return Promise.reject(err)
})

// 5.相应拦截器
Axios.interceptors.response.use((response)=>{
    return response
},(err)=>{
    return Promise.reject(err)
})

export default  request

2-2、ajax函数层

api文件夹下面的acount.js账号api层

// 引入封装好的request
import request  from "@/utils/request";

// 注册请求
export const register = (data)=>{
    return request({
        url:'/users/register',
        method:'POST',
        data:data
    })
}
// 登录请求
export const login = (data)=>{
    return request({
        url:'/users/login',
        method:'POST',
        data:data
    })
}

2-3、组件层

login.vue组件中使用它

async login(){
      const params = {'username':this.loginRuleForm.username,'password':this.loginRuleForm.password}
      const res = await login(params)
      console.log(res.data);
      if(res.data.code == 200){
        this.$message.success(res.data.msg)
        this.$router.push('/managehome')
      }else{
        this.$message.error(res.data.msg)
      }
    }

三、请求拦截器

**任务:**拦截前端发送请求,携带token

3-1、携带token思路

1.从本地存储拿到token给config.headers.Authorization一个token值
2.判断本地是否有token,如果有才携带

请求拦截器代码:

// 4.请求拦截器
request.interceptors.request.use((config)=>{
    const token = localStorage.getItem('token')
    // 如果token存在就携带token到服务器
    if(token){
        config.headers.Authorization = token
    }
    return config
},(err)=>{
    return Promise.reject(err)
})

四、响应拦截器

**任务:**拦截后端返回的数据进行操作,弹出成功或者失败的提示信息

4-1、拦截操作数据思路

1.response就是返回来的数据
2.response.data拿到返回来的数据信息
3.进行判断
4.按需引入elementUI的Message

响应拦截器代码:

// 5.响应拦截器
request.interceptors.response.use(response=>{
    console.log('响应拦截器',response);
    if(response.data.code == 200){
        Message.success(response.data.msg)
      }else{
        Message.error(response.data.msg)
      }
    return response
},(err)=>{
    return Promise.reject(err)
})
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用axios库来进行请求拦截和响应拦截,然后在Vue3中使用alova来封装这些拦截器。 首先安装axios和alova库: ``` npm install axios --save npm install aloba --save ``` 然后在项目中创建一个api.js文件,用来封装axios请求响应拦截: ```javascript import axios from 'axios'; import { createApi } from 'aloba'; // 创建axios实例 const instance = axios.create({ baseURL: 'http://localhost:3000', }); // 请求拦截器 instance.interceptors.request.use((config) => { // 在请求头中添加token等信息 config.headers.Authorization = 'Bearer ' + localStorage.getItem('token'); return config; }); // 响应拦截器 instance.interceptors.response.use((response) => { // 如果响应状态码为401,则跳转到登录页 if (response.status === 401) { location.href = '/login'; } return response.data; }); // 将axios实例传入createApi中,创建一个api实例 const api = createApi(instance); export default api; ``` 在上面的代码中,我们首先创建了一个axios实例,并对其进行了请求拦截和响应拦截。然后将该实例传入到alova的createApi方法中,创建一个api实例,并使用export default导出。 然后在Vue3组件中使用该api实例来发送请求: ```javascript import api from './api.js'; export default { async mounted() { try { const res = await api.get('/user'); console.log(res); } catch (error) { console.log(error); } }, }; ``` 在上面的代码中,我们首先引入了刚才封装好的api.js文件,并使用该实例发送了一个get请求。由于我们在响应拦截器中对响应进行了处理,所以我们可以直接拿到响应数据,而不是整个响应对象。 这样,我们就可以在Vue3中使用alova封装请求拦截和响应拦截了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

忧郁火龙果

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

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

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

打赏作者

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

抵扣说明:

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

余额充值