【React】React+TS 前端工程化 Axios二次封装

简介: 【React】React+TS 前端工程化 Axios二次封装

【React】React+TS 前端工程化 Axios二次封装

import axios, {
    AxiosError,
    AxiosInstance,
    AxiosRequestConfig,
    AxiosResponse,
    InternalAxiosRequestConfig
} from "axios";
//接口地址
const baseURL = "http://localhost:3000"
const service: AxiosInstance = axios.create({
    baseURL,
    //超时时间
    timeout: 5000,
})
//添加请求连拦截器
service.interceptors.request.use((config: InternalAxiosRequestConfig) => {
    //在发送请求之前做些什么
    const token: string | null = sessionStorage.getItem("token") || null
    if (token) {
        config.headers['Authorization'] = token
    }
    return config
}, (error: AxiosError) => {
    //对请求错误做些什么
    console.log(error, 'request-error')
    return Promise.reject(error)
})
//添加响应拦截器
service.interceptors.response.use((response: AxiosResponse) => {
    //2xx 范围内的状态码都会触发该函数。
    //对响应数据做点什么
    return response;
}, (error: AxiosError) => {
    //超出 2xx 范围的状态码都会触发该函数
    //对响应错误做点什么
    console.log(error, 'response-error')
    const {response} = error;
    // 处理 HTTP 网络错误
    let message = '';
    // HTTP 状态码
    const status = response?.status;
    switch (status) {
        case 401:
            message = 'token 失效,请重新登录';
            // 这里可以触发退出的 action
            break;
        case 403:
            message = '拒绝访问';
            break;
        case 404:
            message = '请求地址错误';
            break;
        case 500:
            message = '服务器故障';
            break;
        default:
            message = '网络连接故障';
    }
    console.log(message, "response-error-msg")
    return Promise.reject(error);
})
export const http = {
    get<T>(url: string, config?: AxiosRequestConfig): Promise<T> {
        return service.get(url, config)
    },
    post<T>(url: string, data?: object, config?: AxiosRequestConfig): Promise<T> {
        return service.post(url, data, config)
    },
    //...
}
export default service;
相关文章
|
4天前
|
前端开发 JavaScript API
阿珊比较Vue和React:两大前端框架的较量
阿珊比较Vue和React:两大前端框架的较量
|
5天前
|
开发框架 Dart 前端开发
【Flutter前端技术开发专栏】Flutter与React Native的对比与选择
【4月更文挑战第30天】对比 Flutter(Dart,强类型,Google支持,快速热重载,高性能渲染)与 React Native(JavaScript,庞大生态,热重载,依赖原生渲染),文章讨论了开发语言、生态系统、性能、开发体验、学习曲线、社区支持及项目选择因素。两者各有优势,选择取决于项目需求、团队技能和长期维护考虑。参考文献包括官方文档和性能比较文章。
【Flutter前端技术开发专栏】Flutter与React Native的对比与选择
|
3天前
|
前端开发 JavaScript API
前端工程化-babel、corejs、postcss
前端工程化-babel、corejs、postcss
8 0
|
3天前
|
前端开发
React Hooks - useState 的使用方法和注意事项(1),web前端开发前景
React Hooks - useState 的使用方法和注意事项(1),web前端开发前景
|
4天前
|
资源调度 前端开发 JavaScript
用 Axios 提升前端异步请求的效率
用 Axios 提升前端异步请求的效率
|
4天前
|
前端开发 JavaScript 安全
第十篇 Axios最佳实战:前端HTTP通信的王者之选
第十篇 Axios最佳实战:前端HTTP通信的王者之选
|
5天前
|
前端开发 JavaScript 开发者
【专栏:HTML与CSS前端技术趋势篇】前端框架(React/Vue/Angular)与HTML/CSS的结合使用
【4月更文挑战第30天】前端框架React、Vue和Angular助力UI开发,通过组件化、状态管理和虚拟DOM提升效率。这些框架与HTML/CSS结合,使用模板语法、样式管理及组件化思想。未来趋势包括框架简化、Web组件标准采用和CSS在框架中角色的演变。开发者需紧跟技术发展,掌握新工具,提升开发效能。
|
5天前
|
JSON 前端开发 Java
前端axios传参总结
该文介绍了在前后端分离的开发中,前端使用axios向后端Spring传递参数的两种主要方法。针对@RequestParam注解,推荐使用params传参,将参数格式化为x-www-form-urlencoded,或者使用FormData和qs.stringify。对于@RequestBody,Axios的data传参默认为JSON格式,直接传入对象即可。
|
5天前
|
开发框架 缓存 前端开发
|
5天前
|
前端开发 JavaScript 开发者
【专栏】前端工程化的重要性,强调构建工具在其中的角色,如Webpack和Rollup
【4月更文挑战第27天】本文探讨了前端工程化的重要性,强调构建工具在其中的角色,如Webpack和Rollup。Webpack以其灵活性和插件系统适用于复杂SPA项目,建议开发者理解其核心概念并优化性能。Rollup则专注于JavaScript模块打包,生成更小、更快的代码,适合小型至中型项目和库创建,以其Tree-shaking技术减小代码体积。开发者应根据项目需求、团队技术和生态选择合适工具,掌握核心原理以提升开发效率和质量。