react用redux 做的todolist
### 1. 创建项目
create - react - app 项目名(shop)
### 2. 进入项目,下载redux
cnpm install redux --save
### 3. 在src中创建几个文件夹
App ----->App.css App.js
store------>store.js
todo----->to.js
reducer------>reducer.js
list ---->list.js
### 4. 在todo.js中
import React, {Component} from 'react';
import store from "../store/store";
class Todo extends Component {
    constructor(props) {
        super(props);
         this.state={
             tt:""//--->初始化一个状态 
         }
    }
    ch(e){//--->input,onChange事件
        this.setState({tt:e.target.value});
    }
    add(){//--->添加事件
        store.dispatch({type:"add",d:{t:this.state.tt}});//--->将数据派发到reducer.js页面中操作
      this.setState({tt:""})//--->当前的input框中的数据值为空
    }
    render() {
        return (
            <div>
                <input type="text" value={this.state.tt} onChange={this.ch.bind(this)}/>
                <input type="button" onClick={this.add.bind(this)} value="添加"/>
            </div>
        );
    }
}
export default Todo;
### 5. 在list.js 中
import React, {Component} from 'react';
import store from "../store/store"
class List extends Component {
    constructor(props) {
        super(props);
        var s1=store.getState();//--->获取仓库数据
        this.gets=this.gets.bind(this);//--->改变this指向 
        store.subscribe(this.gets);//--->设置监听,再次更新数据
       this.state={
           list:s1.arr
       }
    }
    gets(){
        var s=store.getState();//--->获取仓库数据 
        this.setState({list:s.arr});//--->更新当前数据 
    }
    del(n){//--->删除事件 --->派发到reducer.js中进行操作
        store.dispatch({type:"del",data:{i:n}})
    }
    ck(n){//--->多选框事件 
        store.dispatch({type:"ck",data:{i:n}});
    }
    finished(){//--->数量事件  
       var list=this.state.list;
       var s=0;
       list.forEach((v,i)=>{
           if(v.done){//--->如果多选框被选中了,执行s++,否则不会执行
               s++;
           }
       })
        return s;
    }
    qh(n){//--->点击添加的文本,input显示,该文本隐藏  
        store.dispatch({type:"qh",data:{i:n}});
    }
    ob(n){//--->点击input框,文本显示,该input框隐藏 
        store.dispatch({type:"ob",data:{i:n}});
    }
    chh(n,e){//--->在input框中修改文本数据  
        store.dispatch({type:"chh",data:{i:n,c:e}});
    }
    render() {
        return (
            <div>
                <h2>已完成{this.state.list.length-this.finished()}</h2>
                <ul>
                    {
                        this.state.list.map((v,i)=>{
                           if(!v.done){
                               return <li key={i}>
                                   <input type="checkbox" defaultChecked={v.done}
                                          onClick={this.ck.bind(this,i)}/>
                                   <span style={{display:v.show?"inline-block":"none"}}
                                   onClick={this.qh.bind(this,i)}>{v.title}</span>
                                   <input type="text" style={{display:!v.show?"inline-block":"none"}}
                                   onBlur={this.ob.bind(this,i)} value={v.title}
                                   onChange={this.chh.bind(this,i)}/>
                                   <input type="button" value="删除" onClick={this.del.bind(this,i)}/>
                               </li>
                           }
                        })
                    }
                </ul>
                <h2>未完成{this.finished()}</h2>
                <ul>
                    {
                        this.state.list.map((v,i)=>{
                            if(v.done){
                                return <li key={i}>
                                    <input type="checkbox" defaultChecked={v.done}
                                           onClick={this.ck.bind(this,i)}/>
                                    {v.title}
                                    <input type="button" value="删除" onClick={this.del.bind(this,i)}/>
                                </li>
                            }
                        })
                    }
                </ul>
            </div>
        );
    }
}
export default List;
### 6. 在reducer.js中
也可在该页面中加入本地储存
var s={//--->定义一个初始值 
    t:"",
    arr:[]
}
function reducer(start=s,action){
    switch (action.type) {
        case "add"://--->添加事件   
            var s1=JSON.parse(JSON.stringify(start));//--->深度复制
            var item={
                title:action.d.t,
                done:false,
                show:true
            }
            s1.arr.push(item);
            return s1;
        case "del"://--->删除事件  
            var s1=JSON.parse(JSON.stringify(start));//--->深度复制
            s1.arr.splice(action.data.i,1);
            return s1;
        case "ck"://--->多选框事件  
            var s1=JSON.parse(JSON.stringify(start));//--->深度复制
            s1.arr[action.data.i].done=!s1.arr[action.data.i].done;
            return s1;
        case "qh"://--->点击添加的文本隐藏事件,input框显示
            var s1=JSON.parse(JSON.stringify(start));//--->深度复制
            s1.arr[action.data.i].show=!s1.arr[action.data.i].show;
            return s1;
        case "ob"://--->点击input框隐藏事件,文本显示
            var s1=JSON.parse(JSON.stringify(start));//--->深度复制
            s1.arr[action.data.i].show=!s1.arr[action.data.i].show;
            return s1;
        case "chh"://--->在input框中修改文本事件
            var s1=JSON.parse(JSON.stringify(start));//--->深度复制
            s1.arr[action.data.i].title=action.data.c.target.value;
            return s1;
        default:
            return start;
    }
}
export default reducer;
### 7. 在store.js中
import {createStore} from "redux";//--->引入redux模块
import reducer from "./reducer/reducer";//--->引入reducer.js文件
var store=createStore(reducer);//--->创建仓库  
export default store;//--->导出
###欢迎大家评论, 如有不足请指正, 可以一起交流,学习,一起进步   !!!!
												
											react用redux 做的todolist的更多相关文章
- 14. react 基础 redux 的编写 TodoList 功能
		
1. 安装 redux 监听工具 ( 需要翻墙 ) 打开 谷歌商店 搜索 redux devtool 安装第一个即可 2. 安装 redux yarn add redux 3. 创建 一个 store ...
 - React之 redux 的简单介绍及使用
		
1.为什么使用redux?在小型react项目的开发中 ,view(视图层)中的数据模型(即数据),可以存放在组件中的 state 对象,换句话说页面中的动态数据存放在 state 中. 但对于开发大 ...
 - 实例讲解react+react-router+redux
		
前言 总括: 本文采用react+redux+react-router+less+es6+webpack,以实现一个简易备忘录(todolist)为例尽可能全面的讲述使用react全家桶实现一个完整应 ...
 - 详解 Node + Redux + MongoDB 实现 Todolist
		
前言 为什么要使用 Redux? 组件化的开发思想解放了繁琐低效的 DOM 操作,以 React 来说,一切皆为状态,通过状态可以控制视图的变化,然后随着应用项目的规模的不断扩大和应用功能的不断丰富, ...
 - 结合React使用Redux
		
前面的两篇文章我们认识了 Redux 的相关知识以及解决了如何使用异步的action,基础知识已经介绍完毕,接下来,我们就可以在React中使用Redux了. 由于Redux只是一个状态管理工具,不针 ...
 - 基于 React.js + Redux + Bootstrap 的 Ruby China 示例  (转)
		
一直学 REACT + METEOR 但路由部分有点问题,参考一下:基于 React.js + Redux + Bootstrap 的 Ruby China 示例 http://react-china ...
 - 基于react+react-router+redux+socket.io+koa开发一个聊天室
		
最近练手开发了一个项目,是一个聊天室应用.项目虽不大,但是使用到了react, react-router, redux, socket.io,后端开发使用了koa,算是一个比较综合性的案例,很多概念和 ...
 - 最新的chart 聊天功能( webpack2 + react + router + redux + scss + nodejs + express  + mysql + es6/7)
		
请表明转载链接: 我是一个喜欢捣腾的人,没事总喜欢学点新东西,可能现在用不到,但是不保证下一刻用不到. 我一直从事的是依赖angular.js 的web开发,但是我怎么能一直用它呢?看看最近火的一塌糊 ...
 - 【前端】react and redux教程学习实践,浅显易懂的实践学习方法。
		
前言 前几天,我在博文[前端]一步一步使用webpack+react+scss脚手架重构项目 中搭建了一个react开发环境.然而在实际的开发过程中,或者是在对源码的理解中,感受到react中用的最多 ...
 
随机推荐
- LeetCode 339. Nested List Weight Sum
			
原题链接在这里:https://leetcode.com/problems/nested-list-weight-sum/ 题目: Given a nested list of integers, r ...
 - LeetCode 317. Shortest Distance from All Buildings
			
原题链接在这里:https://leetcode.com/problems/shortest-distance-from-all-buildings/ 题目: You want to build a ...
 - 题解 [51nod1340]地铁环线
			
题解 [51nod1340]地铁环线 题面 解析 本文参考这篇博客 一开始看到只有120行就打算写一写, 结果一刚就是三个星期摆摆摆 本来是当查分约束入门学的. step 1 首先来考虑下如果已知总长 ...
 - HDU 6000 - Wash
			
/* HDU 6000 - Wash [ 贪心 ] 题意: L 件衣服,N 个洗衣机,M 个烘干机,给出每个洗衣机洗一件衣服的时间和烘干机烘干一件衣服的时间,问需要的最少时间是多少 分析: 先求出L件 ...
 - 006_硬件基础电路_MOS管
			
从文档中提取有用信息 链接:https://pan.baidu.com/s/1fR7ZyGDgapOdd-FtjQ6m8Q提取码:an11 复制这段内容后打开百度网盘手机App,操作更方便哦 判断三个 ...
 - PHP 调用 shell
			
可以使用的命令: popenfpassthrushell_execexecsystem 1.popen resource popen ( string command, string mode ) 打 ...
 - Python学习之--基础语法
			
一.定义 Python 是一种解释型.面向对象.动态数据类型的高级程序设计语言. 二.Python变量的命名规则 1. 变量名只能包含字母.数字和下划线: 2. 变量名不能包含空格: 3. 不要将Py ...
 - splay 1296 营业额统计
			
有一个点超时,确实是个很简单的splay#include<cstdio> #include<iostream> using namespace std; int n,shu[1 ...
 - 【原创】go语言学习(十五)IO操作2
			
目录 文件打开和读写 读取压缩文件 bufio原理和cat命令实现 defer详解 文件打开和读写 1. 文件是存储在外部介质上的数据集合. A. 文件分类:文本文件和二进制文件 B. 文件存取方式: ...
 - Input类中常用的验证方式
			
Deolin一般将Input类对象作为POST请求方法的参数, Input类的域与前端的数据结构一一对应,由于后端不应该相信前端传过来的任何数据, 所以前端的数据对象先绑定到Input对象中,通过JS ...