16 react 发送异步请求获取数据 和 使用Redux-thunk中间件进行 ajax 请求发送
1.发送异步请求获取数据
1.引入 axios ( 使用 yarn add axios 进行安装 )
import axios from 'axios';
2. 模拟 在元素完成挂载后加载数据 并初始化 redux
# TodoList.js
componentDidMount(){
axios.get('http://xxx/xxx').then( ( response ) => {
const data = response.data;
const action = {
type: 'init_store_data',
value: data
}
store.dispatch(action);
})
}
# reducer.js
export default (status, action)=>{
if( action.type === 'init_store_data' ){
const newState = JSON.parse(JSON.stringify( status ));
newState.list = action.value ;
return newState;
}
}
2. 使用Redux-thunk中间件进行 ajax 请求发送
当 ajax请求很多 的时候 需要把 异步请求分装到其他地方进行管理
此时就需要 使用 redux-thunk
1. 安装 redux-thunk
yarn add redux-thunk
2.使用 redux-thunk
创建 store 并使用 applyMiddleware 引入 redux-thunk 方法
#store/index.js
import {createStore, applyMiddleware, compose} from 'redux';
import reducer from './reducer';
import thunk from 'redux-thunk';
// 校验 redux devtool 是否存在
const composeEnhancers =
window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ?
window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__({}) : compose;
// composeEnhancers 引入 thunk 中间件
const enhancer = composeEnhancers(
applyMiddleware(thunk)
);
// 合并后的中间件 作为 redux 的中间件
const store = createStore(reducer, enhancer);
export default store;
#创建 action 文件夹 并在 action 文件夹下创建 index.js 并写入
import axios from 'axios';
export const loadInitData = ()=>{
return (dispatch)=>{
axios.get('http://index.com/front/article')
.then((res)=>{
const data = res.data.data.map((val)=>val.title);
const action = {
type : 'init_data',
value : data
}
dispatch(action);
})
}
}
# store 下的 reducer.js 添加 类型判断
if(action.type === 'init_data'){
const newState = JSON.parse(JSON.stringify(state))
newState.list = action.value;
return newState;
}
# TodoList.js 修改 componentDidMount
import { loadInitData } from './action';
componentDidMount(){
const action = loadInitData();
store.dispatch(action);
}
即可异步发送 ajax 请求
16 react 发送异步请求获取数据 和 使用Redux-thunk中间件进行 ajax 请求发送的更多相关文章
- 向.net后端发送请求获取数据,在前端动态填充表格
		
实现效果 实现步骤 通过Ajax请求的方式 1.在前端定义Table 2.通过Ajax向.net后端发送数据请求 3.在.net后端定义方法供前端调用,并返回所需的数据 4.通过构造字符串的方式,将后 ...
 - ajax异步请求获取数据,实现滚动数字的效果。
		
BackgroundPositionAnimate.js下载 需要导入的js: <script type="text/javascript" src="js/jqu ...
 - jQuery使用ajax跨域请求获取数据
		
jQuery使用ajax跨域请求获取数据 跨域是我在日常面试中经常会问到的问题,这词在前端界出现的频率不低,主要原因还是由于安全限制(同源策略, 即JavaScript或Cookie只能访问同域下的 ...
 - Salesforce LWC学习(十四) Continuation进行异步callout获取数据
		
本篇参考: https://developer.salesforce.com/docs/component-library/documentation/en/lwc/lwc.apex_continua ...
 - 关于前端ajax请求获取数据成功之后无法操作数据的原因及解决方法
		
前言:做项目的时候我用ajax请求json数据,遍历使用数据时却发现页面无响应.关于这个问题今天有个朋友又问了我一次,记录一下.由于我没有记录,这里用我朋友的图片. 代码现象: 这里他是使用alert ...
 - 总结:kathasis如何发送get请求获取数据
		
1.进入前端页面,找到对应的模块,开始塞字段数据. 2.如果字段为基本类型,如String,比如website,则在前段界面,右击,inspect,找到对应的代码所处的jsp,跳转到该jsp,通过该j ...
 - uni-app如何解决在for循环里调用异步请求获取数据顺序混乱问题?
		
总结/朱季谦 先前有一次做uni-app的js接口对接时,遇到过这样的情况,在for循环里,调用一个异步请求时,返回来的值顺序是乱的,因此,在以下的代码里,push到数组里的值,每次的顺序可能都是不一 ...
 - urllib模块通过post请求获取数据
		
功能: 输入你要查找的单词,会返回相对应的结果 import urllib.request import urllib.parse import json class youdaoSpider: de ...
 - ios  异步多线程 获取数据
		
简介 iOS有三种多线程编程的技术,分别是: (一)NSThread (二)Cocoa NSOperation (三)GCD(全称:Grand Central Dispatch) 这三种编程方式 ...
 
随机推荐
- Java中Compareable和Comparator两种比较器的区别
			
Java中Compareable和Comparator两种比较器的区别 参考原文链接:https://www.cnblogs.com/ldy-blogs/p/8488138.html 1.引言 在ja ...
 - 修bug感悟
			
今天遇到了两个问题: 1. 使用 python 的 PIL 库读取照片的尺寸,对于有些图片,长宽和显示的效果相反,原因是照片中的 exif 有个属性 orientation,表示图片的翻转角度,详细说 ...
 - express写的接口在疯狂刷新几十次后,服务器挂掉
			
用到的命令行: show status like 'Threads%'; show variables like '%max_connections%'; show global status lik ...
 - JDBC Connection Configuration配置正确,提示Error preloading the connection pool
			
JDBC Connection Configuration配置正确,提示Error preloading the connection pool JDBC 请求报错,提示: 因为之前执行是正确的,这次 ...
 - SciPy 特殊函数
			
章节 SciPy 介绍 SciPy 安装 SciPy 基础功能 SciPy 特殊函数 SciPy k均值聚类 SciPy 常量 SciPy fftpack(傅里叶变换) SciPy 积分 SciPy ...
 - Redis官方Tutorial
			
基本命令 包括SET , GET , INCR , DEL , EXPIRE , TTL SET server:name "10" GET server:name IN ...
 - JVM配合IDEA远程调试
			
前言 如果测试环境中运行的jar包项目报错,需要排错时,会不太方便,这个时候就可以通过远程调试的方式,在本地打断点的方式进行调试 正文 一.首先,运行测试环境的jar包需要加以下参数: java -j ...
 - Java提升二:Lambda表达式与方法引用
			
1.Lambda表达式 1.1.定义 lambda表达式是对于函数式接口(只含有一个抽象方法的接口)的简洁实现方式.它与匿名内部类的作用相似,但是就使用范围而言,匿名内部类更为广泛,而lambda表达 ...
 - JS: 复选框——ALL与A、B、C(选中ALL同时选中各子项)
			
<!DOCTYPE html><html> <head> <meta charset="utf-8"> <title> ...
 - 解决d7在更高版本上运行乱码问题,或者是调用更高版本的dll
			
将String类型改成WideString类型即可