axios 进阶

这篇具有很好参考价值的文章主要介绍了axios 进阶。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

axios 进阶

接口传参方式

使用 xhr 原生技术或者是 axios 时,它的 post 传参方式是键值对的形式 key=value。但是在实际开发中一般是使用对象的形式定义数据,方便读取和赋值。所以当我们需要发起请求时可以通过 qs 这一款插件将对象转成键值对形式,也可以将键值对形式转成对象,这样就省去了我们自己手动转换的代码。

:::warning 注意
接下来的会在上一个 axios 案例的基础上去做调整,如需要请查看 axios 使用。
:::


  1. 通过命令安装 qs 插件
$ yarn add qs
  1. 修改传参方式
import axios from 'axios'
import qs from 'qs'

const data = qs.stringify({
    account: 'test',
    password: '123456'
})

const p1 = axios({
    method: 'post',
    url: 'https://study.noxussj.top/api/login',
    data: data,
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
    }
})

p1.then((res) => {
    console.log(res.data)
})
  1. 修改后预览效果,依然是可以正常请求接口。

axios 进阶,前端,javascript

请求拦截器

请求拦截器一般是指在请求前需要做的一些处理,例如配置默认请求参数,或者把对象转成键值传参对方式等。这里要记住,每一次新的请求都会先经过请求拦截器。例如我们可以把 qs 转换方法写在请求拦截器中,这样就不需要在每次请求前都要调用 qs 做数据处理,从而节省了部分代码,也让请求参数格式统一成对象形式。

:::warning 注意
基于上面的案例在继续做优化,如需要请查看 axios 接口传参方式。
:::

import axios from 'axios'
import qs from 'qs'

/**
 * 请求拦截器
 */
axios.interceptors.request.use((config) => {
    config.data = qs.stringify(data)

    return config
})

/**
 * 发起请求
 */
const data = { account: 'test', password: '123456' }

const p1 = axios({
    method: 'post',
    url: 'https://study.noxussj.top/api/login',
    data: data,
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded'
    }
})

p1.then((res) => {
    console.log(res.data)
})

修改后预览效果,依然是可以正常请求接口。

axios 进阶,前端,javascript

响应拦截器

响应拦截器一般是指接口响应成功,准备返回接收的数据之前做的一些处理。例如只返回核心部分数据、判断后端的 code 是否正常,错误则弹出提示框提示等。这里要记住,每一次新的请求数据返回之前都会先经过响应拦截器。

:::warning 注意
基于上面的案例在继续做优化,如需要请查看 axios 请求拦截器。
:::

import axios from 'axios'
import qs from 'qs'

/**
 * 请求拦截器
 */
axios.interceptors.request.use((config) => {
    config.data = qs.stringify(data)

    return config
})

/**
 * 响应拦截器
 */
axios.interceptors.response.use((response) => {
    if (response.data.code !== 200) {
        alert('接口响应失败')
    }

    return response.data
})

/**
 * 发起请求
 */
const data = { account: 'test', password: '123456' }

const p1 = axios({
    method: 'post',
    url: 'https://study.noxussj.top/api/login',
    data: data,
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded'
    }
})

p1.then((res) => {
    console.log(res.data)
})

原文链接:菜园前端文章来源地址https://www.toymoban.com/news/detail-669343.html

到了这里,关于axios 进阶的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • javascript常见100问|前端基础知识|问ajax-fetch-axios-区别请用 XMLHttpRequestfetch 实现 ajax节流和防抖px em rem vw/箭头函数的缺点

    HTML CSS JS HTTP 等基础知识是前端面试的第一步,基础知识不过关将直接被拒。本章将通过多个面试题,讲解前端常考的基础知识面试题,同时复习一些重要的知识点。 扎实的前端基础知识,是作为前端工程师的根本。基础知识能保证最基本的使用,即招聘进来能干活,能产出

    2024年04月27日
    浏览(51)
  • axios 进阶

    使用 xhr 原生技术或者是 axios 时,它的 post 传参方式是键值对的形式 key=value 。但是在实际开发中一般是使用对象的形式定义数据,方便读取和赋值。所以当我们需要发起请求时可以通过 qs 这一款插件将对象转成键值对形式,也可以将键值对形式转成对象,这样就省去了我们

    2024年02月11日
    浏览(27)
  • Axios使用方法详解,从入门到进阶

    目录 🌳 Axios的诞生 🌳 Axios的介绍 定义 原理 特性 浏览器支持情况 如何安装  🌳 Axios的使用 ◼️ 创建vue项目 ◼️ Axios的基础用法(get、post、put 等请求方法) get方法 post方法 put和patch方法  delete方法 并发请求 ◼️ Axios进阶用法(实例、配置、拦截器、取消请求等) 1、

    2024年02月08日
    浏览(41)
  • 如何通过 Axios 和 JavaScript 使用 OpenAI API

    领先的 AI 研究实验室 OpenAI 创建了一个强大的 API,允许开发人员利用尖端的 AI 功能并使用 GPT3 等生成语言模型。在本教程中,我们将向您展示如何将 OpenAI API 与 Axios 和 JavaScript 结合使用,让您一窥由 AI 驱动的 Web 开发的未来。 Axios 是一个流行的 JavaScript 库,用于发出 HTTP

    2024年02月07日
    浏览(45)
  • JAVAWEB项目--POST完整交互(servlet,axios,JavaScript)

    post交互 js:   后端servlet: 响应前端:   前端接收:  

    2024年02月14日
    浏览(33)
  • axios 实战进阶练习( axios 封装篇)——基于 Vue3 + Node.js + ElementPlus 实现的联系人列表管理后台的 axios 封装实战

    在之前的文章 axios 实战进阶练习——基于 Vue3 + Node.js + ElementPlus 实现的联系人列表管理后台 中,我们完成了这个 基于 Vue3 + Node.js + ElementPlus 实现的联系人列表管理后台 的项目,其中项目的后端接口是用 Node.js 编写的,通过 axios 来获取接口,所以这篇文章我们来对这个 axi

    2024年02月11日
    浏览(104)
  • vue全家桶进阶之路46:Vue3 Axios拦截器

    在Vue.js 3中,使用Axios与Vue.js 2.x中类似,但是需要进行一些修改和更新,下面是Vue.js 3中Axios的定义和使用方式: 首先,你需要安装Axios和Vue.js 3.x,可以使用npm或yarn等包管理工具安装: 然后,在你的Vue.js 3应用程序中,你可以使用以下代码来导入和使用Axios: 上面的代码使用

    2023年04月20日
    浏览(53)
  • 前端使用axios上传文件

    不用脚手架,引入vue,上传文件实现代码? 要在不使用脚手架的情况下,引入 Vue 并实现上传文件的功能,可以按照以下步骤进行: 在 HTML 文件中引入 Vue 和 Axios 库: 在 HTML 文件中定义 Vue 实例,并编写上传文件相关的代码: 在上述示例中,我们首先在 HTML 文件中定义了一

    2024年02月04日
    浏览(42)
  • 【前端面经】网络-Axios

    Axios是一种流行的JavaScript库,用于在浏览器中进行HTTP请求。它基于Promise API,使其非常易于使用和与其他库集成。Axios提供了许多功能,例如请求和响应拦截,自动转换JSON数据等等。在本篇博客中,我们将讨论Axios背后的原理以及如何使用它进行HTTP请求。 Axios是建立在XMLHtt

    2024年02月02日
    浏览(40)
  • 使用 Axios 实现前端网络请求

    在现代的 Web 开发中,网络请求是不可或缺的一部分。前端开发者需要与后端服务器通信以获取数据、发送表单、或者执行其他操作。在过去,开发者通常使用 XMLHttpRequest (XHR) 对象来处理这些请求,但现在有了更加现代化和简洁的解决方案,其中一种就是 Axios。 Axios 是一个基

    2024年03月23日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包