React中的axios模块及使用方法

目录
  • 1 axios介绍
  • 2 使用方法
    • 2.1 在React中安装axios
    • 2.2 get请求
    • 2.3 post请求:发送表单数据和文件上传
    • 2.4 put请求:对数据进行全部更新
    • 2.5 patch请求:只对更改过的数据进行更新
    • 2.6 delete请求:删除请求(参数可以放在url上,也可以和post一样放在请求体中)

1 axios介绍

axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。它可以提供以下服务:
1、从浏览器中创建XMLHttpRequest(该对象是ajax(异步请求)的核心)
2、从node.js创建http请求
3、支持PromiseAPI
4、拦截请求和响应
5、转换请求数据和响应数据
6、取消请求
7、自动转换JSON数据
8、客户端支持防御XSRF

2 使用方法

2.1 在React中安装axios

npm install axios

2.2 get请求

1、发起不带参数的get请求:

// 方式1
axios({methods: 'get', url: '/url'})
    .then(res => { // 请求成功后的处理
        // res是服务器返回的响应数据
    }).catch(err => { // 请求失败后的处理
    // err是请求失败后的信息
})
// 方式2
axios.get("url")
    .then(res => { // 请求成功后的处理
        // res是服务器返回的响应数据
    }).catch(err => { // 请求失败后的处理
    // err是请求失败后的信息
})

2、发起带参数的get请求:在服务器端获取请求参数的方式 —> req.query.参数名

// 方式1
axios.get("url", {params: {参数名: 参数值}})
    .then(res => {
    })
    .catch(err => {
    })

// 方式2
axios({
    method: "get",
    url: "url",
    params: {
        参数名: 参数值
    }
})
    .then(res => {
    })
    .catch(err => {
    })

2.3 post请求:发送表单数据和文件上传

1、发起不带参数的post请求

// 方式1
axios({
    method: "post",
    url: "url"
}).then(res => {

}).catch(err => {

})

// 方式2
axios.post("url")
    .then(res => {

    }).catch(err => {

})

2、发起带参数的post请求:在服务器端获取请求参数的方式 —> req.body.参数名

// 方式1
axios({
    method: "post",
    url: "url",
    data: {
        参数名: 参数值
    }
}).then(res => {

}).catch(err => {

})

// 方式2
axios.post("url", {参数名: 参数值})
    .then(res => {

    }).catch(err => {

})

2.4 put请求:对数据进行全部更新

1、发起不带参数的put请求

// 方式1
axios({
    method: "put",
    url: "url"
}).then(res => {

}).catch(err => {

})

// 方式2
axios.put("url")
    .then(res => {

    }).catch(err => {

})

2、发起带参数的put请求:在服务器端获取请求参数的方式 —> req.body.参数名

// 方式1
axios({
    method: "put",
    url: "url",
    data: {
        参数名: 参数值
    }
}).then(res => {

}).catch(err => {

})

// 方式2
axios.put("url", {参数名: 参数值})
    .then(res => {

    }).catch(err => {

})

2.5 patch请求:只对更改过的数据进行更新

1、发起不带参数的patch请求

// 方式1
axios({
    method: "patch",
    url: "url"
}).then(res => {

}).catch(err => {

})

// 方式2
axios.patch("url")
    .then(res => {

    }).catch(err => {

})

2、发起带参数的patch请求:在服务器端获取请求参数的方式 —> req.body.参数名

// 方式1
axios({
    method: "patch",
    url: "url",
    data: {
        参数名: 参数值
    }
}).then(res => {

}).catch(err => {

})

// 方式2
axios.patch("url", {参数名: 参数值})
    .then(res => {

    }).catch(err => {

})

2.6 delete请求:删除请求(参数可以放在url上,也可以和post一样放在请求体中)

1、可以像get请求一样包装请求参数:在服务器端获取请求参数的方式 —> req.query.参数名

axios.delete('url', {
    params: {
        参数名: 参数值
    }
}).then(res => {
}).catch(err => {
})

2、可以像post请求一样包装请求参数:在服务器端获取请求参数的方式 —> req.body.参数名

axios.delete('url', {data: {参数名: 参数值}})
    .then(res => {
    })
    .catch(err => {
    })

3 axios的响应结构

{
    // `data` 由服务器提供的响应
    data: {},
    // `status`  HTTP 状态码
    status: 200,
    // `statusText` 来自服务器响应的 HTTP 状态信息
    statusText: "OK",
    // `headers` 服务器响应的头
    headers: {},
    // `config` 是为请求提供的配置信息
    config: {}
}

后台:res.json(result),发送了json格式的数据,相当于:{ data: result }
前端:res.data

例如后台:

res.json({
    code: 1001,
    msg: '橘猫吃不胖'
})

前端:

res.data.code // 1001
res.data.msg // 橘猫吃不胖

到此这篇关于React中的axios模块的文章就介绍到这了,更多相关React axios模块内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • react中的axios模块你了解吗

    目录 一.react中axios模块的使用 1.基于Promise的HTTP库用在浏览器和node.js中 2.创建XMLHttpRequest对象: 3.在react中安装axios 4.发起不带参数的get请求 5.带参数的get请求 6.post请求:发送表单数据和文件上传 7.put请求 8.delete请求 例如: 总结 一.react中axios模块的使用 1.基于Promise的HTTP库用在浏览器和node.js中 可以提供以下服务: (1)从浏览器中创建XMLHttpReque

  • React项目中axios的封装与API接口的管理详解

    目录 前言 安装 引入 环境的切换 请求拦截 响应拦截 api的统一管理 总结 前言 在react项目中,和后台交互获取数据这块,我们通常使用的是axios库,它是基于promise的http库,可运行在浏览器端和node.js中.他有很多优秀的特性,例如拦截请求和响应.取消请求.转换json.客户端防御XSRF等.如果还对axios不了解的,可以移步axios文档. 安装 //使用npm安装 npm install axios; //使用yarn安装 yarn add axios 引入 在项目

  • react axios 跨域访问一个或多个域名问题

    1.react + axios 跨域访问一个域名 配置非常简单,只需要在当前的 package.json 文件里面配置: "proxy":"http://iot-demo-web-dev.autel.com", //当然,这里是一个假地址 像这样: 这样跨域便完成了,当然,也可以像网上那样,多几段代码,像这样: 我不知道你们写入这段代码会怎么样,反正我是会报错,具体报错是怎么我这里没办法展示,因为我的项目已经 运行了 npm run eject 这个命令 报错的意思

  • react使用axios进行api网络请求的封装方法详解

    目录 前言 准备工作 开始封装axios config.js request.js 进行请求 总结 前言 最近写react项目使用到axios进行请求封装,在这里记录一下,希望可以帮助到初学的小伙伴 准备工作 进行请求需要使用axios,所以要先确定你已经安装完成了axios,查看package.json文件 如果没有,请先安装axios npm install axios 开始封装axios 首先在src目录下新建axios文件夹,这里我们新建两个文件,分别是config.js和request

  • 关于React Native使用axios进行网络请求的方法

    在前端开发中,能够完成数据请求的方式有很多,如Ajax.jQuery ajax.axios和fetch等.不过,随着技术的发展,现在能够看到的基本上也就axios和fetch两种. axios是一个基于Promise的Http网络库,可运行在浏览器端和Node.js中,Vue应用的网络请求基本都是使用它完成的.axios有很多优秀的特性,如支持请求的拦截和响应.取消请求.JSON自动转换.客户端防御XSRF等. 使用axios之前,需要先在项目中安装axios插件,安装命令如下. //npm n

  • React中的axios模块及使用方法

    目录 1 axios介绍 2 使用方法 2.1 在React中安装axios 2.2 get请求 2.3 post请求:发送表单数据和文件上传 2.4 put请求:对数据进行全部更新 2.5 patch请求:只对更改过的数据进行更新 2.6 delete请求:删除请求(参数可以放在url上,也可以和post一样放在请求体中) 1 axios介绍 axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中.它可以提供以下服务:1.从浏览器中创建XMLHttpRe

  • React中使用axios发送请求的几种常用方法

    目录 React中安装并引入axios依赖 使用axios进行GET请求 使用axios.get方式 使用axios(config {...}) 使用axios进行POST请求 使用axios.post 使用axios(config {...}) 同时发送多个请求 详细config对象配置项 axios的返回值对象response axios的全局配置 axios的单一实例化配置 axios拦截器的使用 React中安装并引入axios依赖 在React项目中使用axios请求,首先需要安装ax

  • 深入理解React中es6创建组件this的方法

    首发于:https://mingjiezhang.github.io/. 在JavaScript中,this对象是运行时基于函数的执行环境(也就是上下文)绑定的. 从react中的demo说起 Facebook最近一次更新react时,将es6中的class加入了组件的创建方式当中.Facebook也推荐组件创建使用通过定义一个继承自 React.Component 的class来定义一个组件类.官方的demo: class LikeButton extends React.Component

  • 使用Python中的tkinter模块作图的方法

    python简述: Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.自从20世纪90年代初Python语言诞生至今,它逐渐被广泛应用于处理系统管理任务和Web编程.Python[1]已经成为最受欢迎的程序设计语言之一.2011年1月,它被TIOBE编程语言排行榜评为2010年度语言.自从2004年以后,python的使用率是呈线性增长. tkinter模块介绍 tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口.Tk和Tkinter可以

  • node.js中fs文件系统模块的使用方法实例详解

    本文实例讲述了node.js中fs文件系统模块的使用方法.分享给大家供大家参考,具体如下: node.js中为我们提供了fs文件系统模块,实现对文件或目录的创建,修改和删除等操作. fs模块中,所有的方法分为同步和异步两种实现. 有 sync 后缀的方法为同步方法,没有 sync 后缀的方法为异步方法. 一.文件的整个读取 const fs = require('fs'); //参数一表示读取的文件 //参数二表示读取的配置,{encoding:'null', flag:'r'} //encod

  • node.js中path路径模块的使用方法实例分析

    本文实例讲述了node.js中path路径模块的使用方法.分享给大家供大家参考,具体如下: path模块是node.js中处理路径的核心模块.可以很方便的处理关于文件路径的问题. join() 将多个参数值合并成一个路径 const path = require('path'); console.log(path.join('./a', 'b', 'c')); basename() 获取路径中的文件名 const path = require('path'); //获取文件名,包含扩展名 con

  • Vue2中使用axios的3种方法实例总结

    目录 第一种 原始方法 直接在项目中使用(不建议使用) 第二种 将请求挂载到全局( 推荐使用 ) 第三种 将代码进行封装 总结 第一种 原始方法 直接在项目中使用(不建议使用) 这种方法最简单粗暴 优点:不需要做封装,不需要做配置傻瓜式操作,不需要做异步处理 缺点:代码太繁琐,当遇到请求过多的时候,这样写不适合读写 注意:如果你封装的请求有问题解决不掉,可以用这种最原始的方式来解决 <template> <div>{{data}}</div> </template

  • 深入学习nodejs中的async模块的使用方法

    最近在学习nodejs,这两天学习了async模块这个地方知识点挺多的,所以,今天添加一点小笔记. async模块是为了解决嵌套金字塔,和异步流程控制而生.常用的方法介绍 npm 安装好async模块,然后引入就可以使用 var async = require('async'); 1. series(tasks,[callback]) 多个函数从上到下依次执行,相互之间没有数据交互 var task1 =function(callback){ console.log("task1");

  • React中获取数据的3种方法及优缺点

    为了保证的可读性,本文采用意译而非直译. 在执行 I/O 操作(例如数据提取)时,要先发送网络请求,然后等待响应,接着将响应数据保存到组件的状态,最后进行渲染. 在 React 中生命周期方法.Hooks和 Suspense是获取数据的方法.接下用事例演示一下如何使用它们并说明每种方法的优点和缺点,以便咱们更好的编写异步操作代码. 1.使用生命周期方法请求数据 应用程序Employees.org做两件事: 1.一进入程序就获取20名员工. 2.可以通过过滤条件来筛选员工. 在实现这两个需求之前,

随机推荐