本文介绍: 使用 xhr 原生技术或者是 axios 时,它的 post 传参方式键值对的形式key=value。但是在实际开发中一般是使用对象的形式定义数据,方便读取赋值。所以当我们需要发起请求可以通过 qs 这一款插件对象转成键值对形式,也可以将键值对形式转成对象,这样就省去了我们自己手动转换代码。:::warning 注意接下来的会在上一个 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. 修改预览效果,依然是可以正常请求接口

请求拦截器

请求拦截器一般是指在请求前需要做的一些处理例如配置默认请求参数,或者把对象转成键值传参对方式等。这里记住,每一次新的请求都会先经过请求拦截器例如我们可以把 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)
})

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

响应拦截

响应拦截器一般是指接口响应成功,准备返回接收数据之前做的一些处理例如返回核心部分数据判断后端的 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://blog.csdn.net/qq2603375880/article/details/132477743

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_29248.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注