### 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的更多相关文章

  1. 14. react 基础 redux 的编写 TodoList 功能

    1. 安装 redux 监听工具 ( 需要翻墙 ) 打开 谷歌商店 搜索 redux devtool 安装第一个即可 2. 安装 redux yarn add redux 3. 创建 一个 store ...

  2. React之 redux 的简单介绍及使用

    1.为什么使用redux?在小型react项目的开发中 ,view(视图层)中的数据模型(即数据),可以存放在组件中的 state 对象,换句话说页面中的动态数据存放在 state 中. 但对于开发大 ...

  3. 实例讲解react+react-router+redux

    前言 总括: 本文采用react+redux+react-router+less+es6+webpack,以实现一个简易备忘录(todolist)为例尽可能全面的讲述使用react全家桶实现一个完整应 ...

  4. 详解 Node + Redux + MongoDB 实现 Todolist

    前言 为什么要使用 Redux? 组件化的开发思想解放了繁琐低效的 DOM 操作,以 React 来说,一切皆为状态,通过状态可以控制视图的变化,然后随着应用项目的规模的不断扩大和应用功能的不断丰富, ...

  5. 结合React使用Redux

    前面的两篇文章我们认识了 Redux 的相关知识以及解决了如何使用异步的action,基础知识已经介绍完毕,接下来,我们就可以在React中使用Redux了. 由于Redux只是一个状态管理工具,不针 ...

  6. 基于 React.js + Redux + Bootstrap 的 Ruby China 示例 (转)

    一直学 REACT + METEOR 但路由部分有点问题,参考一下:基于 React.js + Redux + Bootstrap 的 Ruby China 示例 http://react-china ...

  7. 基于react+react-router+redux+socket.io+koa开发一个聊天室

    最近练手开发了一个项目,是一个聊天室应用.项目虽不大,但是使用到了react, react-router, redux, socket.io,后端开发使用了koa,算是一个比较综合性的案例,很多概念和 ...

  8. 最新的chart 聊天功能( webpack2 + react + router + redux + scss + nodejs + express + mysql + es6/7)

    请表明转载链接: 我是一个喜欢捣腾的人,没事总喜欢学点新东西,可能现在用不到,但是不保证下一刻用不到. 我一直从事的是依赖angular.js 的web开发,但是我怎么能一直用它呢?看看最近火的一塌糊 ...

  9. 【前端】react and redux教程学习实践,浅显易懂的实践学习方法。

    前言 前几天,我在博文[前端]一步一步使用webpack+react+scss脚手架重构项目 中搭建了一个react开发环境.然而在实际的开发过程中,或者是在对源码的理解中,感受到react中用的最多 ...

随机推荐

  1. selenium之python源码解读-WebDriverWait

    一.显示等待 所谓显示等待,是针对某一个特定的元素设置等待时间,如果在规定的时间内找到了该元素,就执行相关的操作,如果在规定的时间内没有找到该元素,在抛出异常 PS:注意显示等待和隐身等待的区别,隐身 ...

  2. shell 编程整合

    1.shell 浮点数运算与比较 https://www.cnblogs.com/shixun/p/6179642.html 将字符串比较的 = 改为数值比较的 -eq 更有效 2.linux she ...

  3. 学习了武沛齐讲的Day10-完

    int       整形 int     将字符串转换为数字 x.bit_length()  ===== 当前数字的二进制,至少用n位表示 str       字符串 x.capitalize()== ...

  4. NetworkX系列教程(5)-查看graph的信息

    小书匠Graph图论 有时候graph建好后,我们并不清除该graph内节点的,边的信息,这就需要调用函数去查看了. 目录: 6.查看Graph的信息 6.1查看graph内节点,边的 6.2查看gr ...

  5. pc页面自动缩放到手机端

    今天做了个pc的页面,看了别人的网站在手机端能把pc端的网页刚好缩放到手机端,看着很舒服. 于是想把自己的页面也这样搞一下,刚开始,想到的是利用css3的缩放来做,想的是当屏幕尺寸改变时缩放整个页面, ...

  6. 使用AwesomeWM作为Mate(Gnome相同) Desktop的窗口管理器

    本文通过MetaWeblog自动发布,原文及更新链接:https://extendswind.top/posts/technical/using_awesomewm_as_wm_of_mate_des ...

  7. centos7 浏览器(firefox)中文乱码

    主要问题在于firefox用了系统没有的字体 百度的方案: 通过yum安装中文字体 (找不到对应的库) 修改firefox的默认字体(尴尬.不知道改哪个才有效) 粗暴的解决方案: 把 windows ...

  8. 用python实现不同格式99乘法表输出

    前言:学习python已经有一段时间了,最近发现有时候会出现一个东西知道,也能写出来,但是说不出来的情况.思考后觉得是基础还不够扎实,只一味写代码,没有深入思考具体实现的逻辑,以及各个点之间的关联.所 ...

  9. SpringBoot JPA懒加载异常 - com.fasterxml.jackson.databind.JsonMappingException: could not initialize proxy

    问题与分析 某日忽然发现在用postman测试数据时报错如下: com.fasterxml.jackson.databind.JsonMappingException: could not initi ...

  10. 免sudo使用docker

    前沿:通过root安装完docker,在普通用户下执行docker相关命令的时候,报权限不足: 查看sock文件的权限: [hadoop@slave1 monitor]$ ll /var/run/do ...