react怎么请求数据异步
react请求数据异步的方法:1、通过“npm i redux-thunk --save npm i axios --save”命令下载thunk;2、在store.js里面引入thunk插件;3、在需要模块的actionCreator里引入中间件“redux-thunk”即可。
本教程操作环境:Windows10系统、react18.0.0版、Dell G3电脑。
react怎么请求数据异步?
react异步请求数据方法。
关于react异步请求数据有很多种方案。
1、saga (用了er6生成器函数)
2、promise
3、thunk
4、…
为什么要用插件啊?是为了改造这个redux的action动作。如果异步的话,我们发动作,actionCreator只有返回对象,而异步这个插件能让你隔一段时间再发这个动作,是为了改造动作用的。
本文用thunk,它可能不是最好的,但是是我用得比较习惯的。
一、下载
npm i redux-thunk --save npm i axios --save
二、引用。在store.js里面引入插件,并使用。
import {createStore,applyMiddleware} from 'redux' //引入applyMiddleware import reducers from './reducers' //总的reducer import thunk from 'redux-thunk' //引入thunk var store = createStore(reducer,applyMiddleware(thunk)); //使用中间件 export default store;
三、发数据
在你需要模块的actionCreator里:
import axios from 'axios' export default { getData(){ return (dispatch)=>{ // 引入中间件redux-thunk后,就可以延迟发出动作 axios.get('http://www.xmyxapp.com/api/tab/1?start=0').then((res)=>{ console.log(res) dispatch({ type:'GETDATA', list:res.data.data.items.list }) }) } } }
四、效果测试
在你需要的模块里面的reducer:
var initState ={ list:[] } export const listReducer = (state = initState, action) => { var newState ={...state}; switch (action.type) { case 'GETDATA': newState.list = action.list // 这个action.list就是该模块actionCreator里传过来的值 return newState; default: return state } }
在store里面总和的reducers:
import {combineReducers} from 'redux' import {listReducer} from '../components/list/reducer' var reducer = combineReducers({ list:listReducer }) export default reducer;
在你需要的模块里面的组件:
import React, { Component } from 'react' import {connect} from 'react-redux' import actionCreator from './actionCreator'; class List extends Component { componentDidMount(){ this.props.getData(); // 调用异步方法获取数据 } render() { console.log(this.props); return ( <div> <ul> { this.props.list.list.map((item)=>{ return item.title?<li key={item.id}>{item.title}</li>:"" }) } </ul> </div> ) } } export default connect((state)=>state,actionCreator)(List);
推荐学习:《react视频教程》
以上是react怎么请求数据异步的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

如何利用React和WebSocket构建实时聊天应用引言:随着互联网的快速发展,实时通讯越来越受到人们的关注。实时聊天应用已经成为现代社交和工作生活中不可或缺的一部分。本文将介绍如何利用React和WebSocket构建一个简单的实时聊天应用,并提供具体的代码示例。一、技术准备在开始构建实时聊天应用之前,我们需要准备以下技术和工具:React:一个用于构建

React前后端分离指南:如何实现前后端的解耦和独立部署,需要具体代码示例在当今的Web开发环境中,前后端分离已经成为一种趋势。通过将前端和后端代码分开,可以使得开发工作更加灵活、高效,并且方便进行团队协作。本文将介绍如何使用React实现前后端分离,从而实现解耦和独立部署的目标。首先,我们需要理解什么是前后端分离。传统的Web开发模式中,前端和后端是耦合在

如何利用React和Flask构建简单易用的网络应用引言:随着互联网的发展,网络应用的需求也越来越多样化和复杂化。为了满足用户对于易用性和性能的要求,使用现代化的技术栈来构建网络应用变得越来越重要。React和Flask是两种在前端和后端开发中非常受欢迎的框架,它们可以很好的结合在一起,用来构建简单易用的网络应用。本文将详细介绍如何利用React和Flask

如何利用React和RabbitMQ构建可靠的消息传递应用引言:现代化的应用程序需要支持可靠的消息传递,以实现实时更新和数据同步等功能。React是一种流行的JavaScript库,用于构建用户界面,而RabbitMQ是一种可靠的消息传递中间件。本文将介绍如何结合React和RabbitMQ构建可靠的消息传递应用,并提供具体的代码示例。RabbitMQ概述:

ReactRouter使用指南:如何实现前端路由控制随着单页应用的流行,前端路由成为了一个不可忽视的重要部分。ReactRouter作为React生态系统中最受欢迎的路由库,提供了丰富的功能和易用的API,使得前端路由的实现变得非常简单和灵活。本文将介绍ReactRouter的使用方法,并提供一些具体的代码示例。安装ReactRouter首先,我们需

如何利用React和GoogleBigQuery构建快速的数据分析应用引言:在当今信息爆炸的时代,数据分析已经成为了各个行业中不可或缺的环节。而其中,构建快速、高效的数据分析应用则成为了许多企业和个人追求的目标。本文将介绍如何利用React和GoogleBigQuery结合起来构建快速的数据分析应用,并提供详细的代码示例。一、概述React是一个用于构建

如何利用React和ApacheKafka构建实时数据处理应用引言:随着大数据与实时数据处理的兴起,构建实时数据处理应用成为了很多开发者的追求。React作为一个流行的前端框架,与ApacheKafka作为一个高性能的分布式消息传递系统的结合,可以帮助我们搭建实时数据处理应用。本文将介绍如何利用React和ApacheKafka构建实时数据处理应用,并

如何利用React和Docker打包和部署前端应用前端应用的打包和部署是项目开发中非常重要的一环。随着现代前端框架的飞速发展,React已经成为了许多前端开发人员的首选。而Docker作为一种容器化解决方案,可以极大地简化应用的部署过程。本文将介绍如何利用React和Docker打包和部署前端应用,并提供具体的代码示例。一、准备工作在开始之前,我们需要先安装
