45_redux_comment应用_redux版本_异步功能
/* * 包含所有action的type名称常量 * */ //添加评论 export const ADD_COMMENT = 'add_comment'; //删除评论 export const DELETE_COMMENT = 'delete_comment'; //接收评论数组 export const RECEIVE_COMMENTS = 'receive_comments'; export const INCREMENT = 'increment';
action-types.js
/* * 包含了所有的action creator(action的工厂函数) * */ import {ADD_COMMENT, DELETE_COMMENT, RECEIVE_COMMENTS} from './action-types' // 同步添加 export const addComment = (comment) => ( {type: ADD_COMMENT, data: comment} ) // 同步删除 export const deleteComment = (index) => ( {type: DELETE_COMMENT, data: index} ) // 同步接收comments const receiveComments = (comments) => ({ type: RECEIVE_COMMENTS, data: comments }) // 异步从后台获取数据 export const getComments = () => { return dispatch => { // 模拟发送ajax请求异步获取数据 setTimeout(() => { const comments = [ {username: 'Tom', content: 'React挺好的!'}, {username: 'Jack', content: 'React太难了!'}, {username: 'Jensen', content: '干就完了!'} ] //分发一个同步的action dispatch(receiveComments(comments)) }, 1000) } }
actions.js
/* * 包含n个reducer函数(根据老的state和action返回一个新的state) * */ import {combineReducers} from 'redux' import {ADD_COMMENT, DELETE_COMMENT, RECEIVE_COMMENTS, INCREMENT} from './action-types' function counter(state = 0, action) { console.log('counter()', state, action) switch (action.type) { case INCREMENT: return state + action.data case DELETE_COMMENT: return state - action.data default: return state } } const initComments = [] function comments(state = initComments, action) { switch (action.type) { case ADD_COMMENT: return [action.data, ...state] case DELETE_COMMENT: return state.filter((comment, index) => index !== action.data) case RECEIVE_COMMENTS: return action.data default: return state } } export default combineReducers({ counter, //指定reducer对应的属性 comments }) // redux向外暴露的state是什么结构? // 是一个对象{counter:2,comments:[]}
reducers.jsx
/* * redux最核心的管理对象store * */ import {createStore, applyMiddleware} from 'redux' import reducers from './reducers' import thunk from 'redux-thunk' export default createStore( reducers, applyMiddleware(thunk) )
store.js
import React from 'react'; import ReactDOM from 'react-dom'; import {Provider} from 'react-redux' import store from './redux/store' import App from './containers/app/app' ReactDOM.render(( <Provider store={store}> <App/> </Provider> ), document.getElementById('root'));
index.js
import React from 'react' import PropTypes from 'prop-types' import {connect} from 'react-redux' import CommentAdd from '../../components/comment-add/comment-add' import CommentList from '../../components/comment-list/comment-list'; import {addComment, deleteComment, getComments} from '../../redux/actions' class App extends React.Component { //定义数据 static propTypes = { comments: PropTypes.array.isRequired, addComment: PropTypes.func.isRequired, deleteComment: PropTypes.func.isRequired, getComments: PropTypes.func.isRequired } componentDidMount() { //异步获取所有评论数组 this.props.getComments() } render() { const {comments, addComment, deleteComment} = this.props return ( <div> <header className="site-header jumbotron"> <div className="container"> <div className="row"> <div className="col-xs-12"> <h1>请发表对React的评论</h1> </div> </div> </div> </header> <div className="container"> <CommentAdd addComment={addComment}/> <CommentList comments={comments} deleteComment={deleteComment}/> </div> </div> ) } } export default connect( state => ({comments: state.comments}),// 说明state就是comments数组 {addComment, deleteComment, getComments} )(App)
app.jsx
45_redux_comment应用_redux版本_异步功能的更多相关文章
- 44_redux_comment应用_redux版本_同步功能
项目结构: components里面的东西没变,将app.jsx移动至containers中 /* * 包含所有action的type名称常量 * */ //添加评论 export const ADD ...
- Spring异步功能
使用 Spring 的异步功能时,实质是使用的 Servlet3 及以上版本的异步功能. Spring 的异步处理机制需要在 web.xml 中全部的 servlet 和 filter 处配置 < ...
- C#各版本新增加功能
本系列文章主要整理并介绍 C# 各版本的新增功能. C# 8.0 C#8.0 于 2019年4月 随 .NET Framework 4.8 与 Visual Studio 2019 一同发布,但是当前 ...
- 【转】C#各版本新增加功能
本系列文章主要整理并介绍 C# 各版本的新增功能. C# 8.0 C#8.0 于 2019年4月 随 .NET Framework 4.8 与 Visual Studio 2019 一同发布,但是当前 ...
- oracle_单向函数_数字化功能
oracle_单向函数_数字化功能 1.abs(x) 为了获得x绝对值 2.ceil(x) 用于获得大于或等于x的最小整数. 3.floor(x) 用于获得小于或等于x 4.mod(x,y ...
- python人工智能爬虫系列:怎么查看python版本_电脑计算机编程入门教程自学
首发于:python人工智能爬虫系列:怎么查看python版本_电脑计算机编程入门教程自学 http://jianma123.com/viewthread.aardio?threadid=431 本文 ...
- java web开发_购物车功能实现
java web开发_购物车功能实现 之前没有接触过购物车的东东,也不知道购物车应该怎么做,所以在查询了很多资料,总结一下购物车的功能实现. 查询的资料,找到三种方法: 1.用cookie实现购物车: ...
- unix网络编程第2版(卷1)_第6章_同步_异步
第6章 I/O复用:select和poll函数 6.1概述 在5.12节中,我们看到TCP客户同时处理两个输入:标准输入和TCP套接口.我们遇到的问题是客户阻塞于(标准输入上的)fgets调用,而服务 ...
- 爬虫必知必会(4)_异步协程-selenium_模拟登陆
一.单线程+多任务异步协程(推荐) 协程:对象.可以把协程当做是一个特殊的函数.如果一个函数的定义被async关键字所修饰.该特殊的函数被调用后函数内部的程序语句不会被立即执行,而是会返回一个协程对象 ...
随机推荐
- uwp应用在debug模式下运行正常,编译为release版本的时候抛出异常
原因是在代码中使用了dynamic关键字,导致release时.net native优化了代码造成元数据丢失 所以在代码中要尽量不用dynamic.
- win10 安装 face_recognition
环境:Python 3.6.4 |Anaconda, Inc.| (default, Jan 16 2018, 10:22:32) [MSC v.1900 64 bit (AMD64)] on win ...
- 《Attention Augmented Convolutional Networks》注意力的神经网络
paper: <Attention Augmented Convolutional Networks> https://arxiv.org/pdf/1904.09925.pdf 这篇文章是 ...
- MySQL Hardware--NUMA与MySQL
MUMA架构 在单实例的MySQL服务器上,通过会为MySQL的Buffer Pool分配50%至70%甚至更高的内存,让MySQL 服务会尽可能多地占用系统资源.在基于NUMA系统中,内存被分配到各 ...
- Java中的锁分类与使用
1. Java锁的种类 在笔者面试过程时,经常会被问到各种各样的锁,如乐观锁.读写锁等等,非常繁多,在此做一个总结.介绍的内容如下: 乐观锁/悲观锁 独享锁/共享锁 互斥锁/读写锁 可重入锁 公平锁/ ...
- Day 18 常用模块(二)
一.随机数:RANDOM 1.(0,1)小数:random.random() 2.[1,10]整数:random.randint(1,10) 3.[1,10)整数:random.randrang(1, ...
- reset Cisco 2960 password
详见:http://www.cahilig.net/2014/04/14/how-reset-cisco-2960-switch-password-without-losing-your-config ...
- cocos CCLayer glDrawArrays(GL_TRIANGLE_STRIP, 0, 4);ios11闪退 spine动画
搜索一下方法,找到后替换不同内容: void PolygonBatch::flush () { if (!_verticesCount) return; GL::bindTexture2D(_text ...
- python io-os
#IO - os import os; #文件改名 #os.rename('io.txt','newio.txt'); #删除文件 #os.remove('io2.txt'); #创建文件夹(目录) ...
- C# .NET XML 序列化为对象,反序列化
如果遇到: 根级别上的数据无效. 行 1,位置 1 .:即无法反序列化(反序列失败),得到对象为null ,把 xml 文本 Trim一下. xml=xml.Trim(); 序列化完毕你可以看 ...