如何在React中做Ajax 请求?
来源:互联网 发布:淘宝拍摄灯光布置图解 编辑:程序博客网 时间:2024/06/05 16:51
如何在React中做Ajax 请求?
首先:React
本身没有独有的获取数据的方式。实际上,就react
而言,它甚至不知道有服务器画面的存在。
React
只是简单地渲染组件,单独从两个地方获取数据:props
和 state
。
因此,为了使用服务器的数据,你需要在你的组件(component)的props
或state
里拿到数据。
你可以将这个过程与服务和数据模型复杂化,就像你所希望的那样,但最终只是组件渲染props
和state
。
选择一个HTTP 库
为了获取来自服务器的数据,你需要一个HTTP
库,网上有很多,最终他们都做同样的事情,但他们有不同的特点。
- 喜欢
Promise
?那就选axios
吧:https://github.com/mzabriskie/axios - 讨厌
Promise
?,但是喜欢callback
?不妨看看superagent
?https://github.com/visionmedia/superagent
当然,你也可以选择自己封装一个ajax库,我喜欢Axios,下面将以这个库作为例子,如果你不喜欢,可以选择其他库看看。
Fetch Data
如下是一个简单的实例,一个组件从subreddit
获取职位。看看这个例子,我们将会了解它是如何工作的
import React from 'react';import ReactDOM from 'react-dom';import axios from 'axios';class FetchDemo extends React.Component { constructor(props) { super(props); this.state = { posts: [] }; } componentDidMount() { axios.get(`http://www.reddit.com/r/${this.props.subreddit}.json`) .then(res => { const posts = res.data.data.children.map(obj => obj.data); this.setState({ posts }); }); } render() { return ( <div> <h1>{`/r/${this.props.subreddit}`}</h1> <ul> {this.state.posts.map(post => <li key={post.id}>{post.title}</li> )} </ul> </div> ); }}ReactDOM.render( <FetchDemo subreddit="reactjs"/>, document.getElementById('root'));
它是如何工作的?
首先,我们将axios
库import
进来。
这个constructor
先调用super
,然后初始化state
,让它拥有一个posts
空数组。
componentDidMount
是关键所在,这个方法将会在组件插入DOM
的第一时间执行。该方法在整个组件的生命周期只会执行一次。
它使用axios.get
方法从subreddit
获取数据,反引号的字符串是ES6
的模板字符串,${}
部分是由表达式的值所取代,所以URL
传递给axios.get
实际上是http://www.reddit.com/r/reactjs.json。
有两点你需要注意的是:
- 你可以在任意的subreddit URL末尾处附加上
.json
并且获得那个职位的json形式的展示 - 如果你忘记
www
,你将会得到一个CORS错误(至少我没有忘记)
因为Axios
使用Promise
,所有我们可以链式调用then
方法来处理response
。获取的职位信息是一点一点的转换后提取的,最重要的一点是,组件的状态(state)是由职位与新数组调用this.setState
更新的,由此触发一个重新渲染,然后职位就可以看见了
- 如何在React中做Ajax 请求?
- 在PHP中如何判断AJAX请求
- 如何在CakePHP中使用Ajax请求
- 如何在ajax请求中设置特殊的RequestHeader
- 如何在ajax请求中设置特殊的RequestHeader
- 如何在ajax请求中设置特殊的RequestHeader
- 如何在ajax请求中设置特殊的RequestHeader
- 如何在laravel中使用post方法的ajax请求
- 在php中,如何判断一个请求是ajax请求还是普通请求? jquery
- 在 ajax 跨域请求中携带 cookie 做身份认证 (xhr withCredentials属性)
- 如何使用Ajax(XMLHttpRequest)发送带参数的请求,以及如何在Servlet中获取请求中的参数
- Ecstore中如何调用发起Ajax请求
- 在struts中处理AJAX请求
- 在struts中处理AJAX请求
- 在ajax请求中使用json数据格式
- 如何在Thymeleaf中实现ajax请求url的可靠构造?
- React学习笔记----如何在html页面中使用react
- 如何在react vr中使用中文
- 以最大连续和为例的算法分析
- 微信开放平台修改微信分享的应用小图标与应用名称,应用名称更改了应用小图标未更改的问题
- Java循环
- POJ3264 Balanced Lineup(线段树,区间最值)
- 自定义变量不能用怎么办,将文件中的数据直接读取到普通变量中
- 如何在React中做Ajax 请求?
- 小白学习日记1:PL/SQL连接本地Oracle数据库Part2
- [Azure]ARM虚拟机整机磁盘快照[1]——创建快照
- jboss domain配置
- 优化Spring配置文件中的数据库连接部分
- STM32启动文件详解1
- SVN : Working copy is too old (format 10, created by Subversion 1.6)
- 崩溃的Python学习过程2——ImportError: No module named PIL(windows)
- 开发环境部署