二次封装ajax和axios

ajax

javascript 复制代码
app.config.globalProperties.$http = function(url, method, data, async, fun) {
	$.ajax({
		url: baseUrl + url,
		type: method,
		dataType: 'json',
		contentType: "application/json",
		xhrFields: {
			withCredentials: true
		},
		headers: {
			"token":localStorage.getItem("token")
		},
		async: async,
		data: JSON.stringify(data),
		success: function(resp) {
			if (resp.code == 200) {
				fun(resp)
			} else {
				ElMessage.error({
					message: resp.msg,
					duration: 1200
				});
			}
		},
		error: function(e) {
			if (e.status == undefined) {
				ElMessage.error({
					message: "前端页面错误",
					duration: 1200
				});
			} else {
				let status = e.status
				if (status == 401) {
					router.push({
						name: 'Login'
					})
				} else {
					ElMessage.error({
						message: e.responseText,
						duration: 1200
					});
				}
			}

		}
	})
}

axios

javascript 复制代码
/对于axios函数库进行二次封装
//你工作的时候axios是否进行二次封装?
// 目的1:利用axios请求,响应拦截器功能
// 目的2:请求拦截器,一般看可以在请求头中携带公共参数:token
// 目的3:响应拦截器,可以简化服务返回的数据,处理http的网络错误
import axios from "axios";
import { ElMessage } from "element-plus";

//利用axios.create方法创建一个axios实例:可以设置基础路径、超时时间的设置
const request = axios.create({
  baseURL: "/api", //请求路径设置
  timeout: 5000, // 超时的时间设置,超出五秒请求就是失败的
});

// 请求拦截器
request.interceptors.request.use((config) => {
  //config:请求拦截器回调注入的对象(配置对象),配置对象的身上最重要的一件事就是headers属性
  //可以通过请求头携带公共参数-token
  return config;
});

request.interceptors.response.use(
  (response) => {
    //响应拦截器成功的回调,一般会进行简化数据
    return response.data;
  },
  (error) => {
    // 处理http网络错误
    let status = error.response.status;
    switch (status) {
      case 404:
        //错误提示信息
        ElMessage({
          type: "error",
          message: "请求失败路径出现问题",
        });
        break;
      case 500 | 501 | 502 | 503 | 504 | 505:
        //错误提示信息
        ElMessage({
          type: "error",
          message: "服务器挂了",
        });
        break;
      case 401:
        ElMessage({
          type: "error",
          message: "参数有误",
        });
        break;
    }

    return Promise.reject(new Error(error.message));
  }
);

export default request;
相关推荐
未来之窗软件服务1 天前
一体化系统(九)智慧社区综合报表——东方仙盟练气期
大数据·前端·仙盟创梦ide·东方仙盟·东方仙盟一体化
陈天伟教授1 天前
人工智能训练师认证教程(2)Python os入门教程
前端·数据库·python
信看1 天前
NMEA-GNSS-RTK 定位html小工具
前端·javascript·html
Tony Bai1 天前
【API 设计之道】04 字段掩码模式:让前端决定后端返回什么
前端
苏打水com1 天前
第十四篇:Day40-42 前端架构设计入门——从“功能实现”到“架构思维”(对标职场“大型项目架构”需求)
前端·架构
king王一帅1 天前
流式渲染 Incremark、ant-design-x markdown、streammarkdown-vue 全流程方案对比
前端·javascript·人工智能
苏打水com1 天前
第十八篇:Day52-54 前端跨端开发进阶——从“多端适配”到“跨端统一”(对标职场“全栈化”需求)
前端
Bigger1 天前
后端拒写接口?前端硬核自救:纯前端实现静态资源下载全链路解析
前端·浏览器·vite
BD_Marathon1 天前
【JavaWeb】路径问题_前端绝对路径问题
前端