首先要有一定的react的基础,里面的一些不做解释(包括项目文件的用法及作用)

  ### 1. 先安装react的插件

npm  install  create-react-app  -g     只需要安装一次即可

### 2. 下载react的脚手架

create-react-app    项目名(todo)

### 3.进入todo     启动项目或者运行的时候

可以   npm     start     或者下载  npm  install  yarn  --save------------>yarn     start     也可以启动

### 4. 创建一个App 文件夹     把App.js 和App.css都放到里面

### 5. 在index.js 中 引入App.js 的路径修改一下   


                 import App from './App/App';

### 6. 创建一个文件夹(to)  里面在新建一个to.js 文件  快捷键rcc     con

### 7. 在App.ja 中引入 

import To from "../todo/to";
<To></To>

### 8 . 在to.js 中编写

import React, {Component} from 'react';

class To extends Component {
constructor(props){
super(props);
this.state={//初始化状态
title:"",//通过他来获取用户的数据,并传递给list
list:[]//创建一个空数组,储存数据,添加
show:false
};
this.ch=this.ch.bind(this);//实现修改this的指向
this.add=this.add.bind(this);//实现修改this的指向
}
ch(e){//获取输入框内,用户输入的内容
this.setState({title:e.target.value});
}
add(){//点击添加按钮,添加数据
// alert(this.state.title);
var list=this.state.list;
var a=this.state.title;
var t={
tt:a,
done:false,
ss:true
}
list.push(t);
this.setState({list,title:""})//更新后的状态
}
del(n){//点击删除按钮,删除数据
var list1=this.state.list;
list1.splice(n,1);
this.setState({list:list1})
}
ck(n){//点击多选框,实现完成与未完成的切换效果
var list2=this.state.list;
list2[n].done=!list2[n].done;
this.setState({list:list2})
}
sl(n){//实现数量,每添加一条数据或者完成一项,会显示不同的数据
var list3=this.state.list;
var s=0;
list3.forEach((v,i,a)=>{
if(v.done){
s++
}
});
return s;
}
da(){//实现点击全选与全不选之间的来回切换效果 有点问题*****
var list4=this.state.list; //arr
     let show =!this.state.show //true
       list4.forEach((v)=>{
        v.done=show
   })  
        this.setState({list:list4,show})
var list=this.state.list;
list.map((v,i)=>{
var s = v.done;
s=!s
v.done = s;
this.setState({s:!s})
// v.done=!v.done
// this.setState({list})
}) }
dd(n){
var list=this.state.list;
list[n].ss=!list[n].ss;
this.setState({list});
}
ds(n){
var list=this.state.list;
list[n].ss=!list[n].ss;
this.setState({list});
}
cc(n,event){//事件的参数都放到最后
var list=this.state.list;
list[n].tt=event.target.value;
this.setState({list});
}
render() {
return (
<div>
<input type="text" value={this.state.title} onChange={this.ch}/>
<button onClick={this.add}>添加</button>
<h3>未完成{this.state.list.length-this.sl()}</h3>
<ul>
{ this.state.list.map((v,i,a)=>{
if(!v.done){
return <li key={i}>
<input type="checkbox" onClick={this.ck.bind(this,i)} defaultChecked={v.done}/> <span style={{display:v.ss?"inline-block":"none"}} onClick={this.dd.bind(this,i)} >{v.tt}</span>
<input type="text" style={{display:!v.ss?"inline-block":"none"}} onBlur={this.ds.bind(this,i)} value={v.tt} onChange={this.cc.bind(this,i)}/> <input type="button" value="删除" onClick={this.del.bind(this,i)}/>
</li>
}
})
}
</ul>
<h3>已完成{this.sl()}</h3>
<ol>
{ this.state.list.map((v,i,a)=>{
if(v.done){
return <li key={i}>
<input type="checkbox" onClick={this.ck.bind(this,i)} defaultChecked={v.done}/>
{v.tt}
<input type="button" value="删除" onClick={this.del.bind(this,i)}/>
</li>
}
})
}
</ol>
<input type="button" value="全选/全不选" onClick={this.da.bind(this)}/>
</div>
);
}
} export default To;
												

react 做的简易todolist的更多相关文章

  1. 4-13 Webpacker-React.js; 用React做一个下拉表格的功能: <详解>

    Rails5.1增加了Webpacker: Webpacker essentially is the decisions made by the Rails team and bundled up i ...

  2. React入门——制作一个TodoList App

    源码 import React, { Component, Fragment } from "react"; class TodoList extends Component { ...

  3. 18 react react-redux 的编写 TodoList

    1. 安装 react-redux yarn add react-redux 2. react-redux 编写 TodoList 使所有子组件 都能使用 store #index.js import ...

  4. React实现一个简易版Swiper

    背景 最近在公司内部进行一个引导配置系统的开发中,需要实现一个多图轮播的功能.到这时很多同学会说了,"那你直接用swiper不就好了吗?".但其实是,因为所有引导的展示都是作为np ...

  5. 使用react做的聊天对话列表

    刚刚接触react   可能写的地方有错误或者不完善的地方欢迎大家给指正 下面开始正题 首先分析页面基于react的特性--把页面中所有显示内容看做模块加载 本页面可以看做一个大的模块,我们暂且命名为 ...

  6. 这几天做完简易酒店管理系统,对Sql Server执行计划的浅显了解。

    我是一名大三的小学生,今天开始我的第一篇博客,最近随便做了一个简易的酒店管理系统,对sql执行计划有了初步的了解. 查看上面语句的预估执行计划,在工具栏中有这个按钮 聚集索引扫描被称为Index Sc ...

  7. .NETCore 快速开发做一个简易商城

    介绍 上一篇介绍 <.NETCore 基于 dbfirst 体验快速开发项目>,讲得不太清楚有些多人没看懂.这次吸取教训,将一个简易商城做为案例,现实快速开发. 本案例用于演示或学习,不具 ...

  8. python之做一个简易的翻译器(一)

    平时经常在网上翻译一些单词,突发奇想,可不可以直接调某些免费翻译网站的接口呢?然后做一个图形界面的翻译小工具?下面开始实践 1.先找一下有哪些免费翻译的接口 百度了一下关键字“免费翻译接口”,然后找到 ...

  9. react做股票、期货交易遇到的问题(不完全是react)及解决方法。

    公司项目主要是做股票及期货行情展示及交易,h5相应的做了一些功能---可以看行情图及模拟交易,实盘交易存在一定的风险,老板希望做自己的产品,这样h5就尴尬了,不过没关系,项目里还是有一定技术含量的-- ...

随机推荐

  1. yum安装出现No package crontabs available解决办法

    其意思是:yum中不存在这个包 所以解决办法是 1.更新yum   更新yum仓库: yum -y update 2.查看包名在yum中是什么   yum search  all crontabs

  2. java.sql.SQLException: connection holder is null;

    一.问题来源分析 出现的错误 : Cause: java.sql.SQLException: connection holder is null; uncategorized SQLException ...

  3. h5css样式

    兼容性前缀: 谷歌:webkit 火狐:moz ie:ms 欧鹏:o选择器: 属性选择器: * = 包含 {href * = 'www'} ^ = 以什么开头 $ = 以什么结尾 伪类选择器: 第一个 ...

  4. Oracle ORA-00600[2662] 解决

    一.问题描述 1.数据库情况 1)数据库版本:11.2.0.4: 2)未开启归档: 3)没有备份:无RMAN备份.无DUMP备份: 4)数据库redo log 日志组,每组只有一个成员: 2.问题出现 ...

  5. ueditor从word粘贴公式

    官网地址http://ueditor.baidu.com Git 地址 https://github.com/fex-team/ueditor 参考博客地址 http://blog.ncmem.com ...

  6. exam8.29

    咕了好几篇后... 我终于开始重新写了 T1: 不会,没思路,暴搜还可能会(一开始我以为暴搜时间复杂度为$\Theta (mn ^ k)$) 于是码出了暴搜... 跑一遍$(4,4,5)$,然后... ...

  7. 搭建自己的博客(二十一):通过django表单实现登录注册

    1.变化的部分

  8. 爬虫(十一):scrapy中的选择器

    Scrapy提取数据有自己的一套机制,被称作选择器(selectors),通过特定的Xpath或者CSS表达式来选择HTML文件的某个部分Xpath是专门在XML文件中选择节点的语言,也可以用在HTM ...

  9. 常见的时间字符串与timestamp之间的转换 时间戳

    这里说的字符串不是一般意义上的字符串,是指在读取日期类型的数据时,如果还没有及时解析字符串,它就还不是日期类型,那么此时的字符串该怎么与时间戳之间进行转换呢? ① 时间字符串转化成时间戳 将时间字符串 ...

  10. 数据层面;MySQL查

    AND 运算优先于OR运算执行(通过括号进行强化) count(*) 会得到包含NULL的数据行数:count(<列明>)会得到NULL之外的数据行数 SQL语句的总逻辑:书写顺序 sel ...