首先要有一定的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. 61、springmvc-异步请求-返回DeferredResult

    61.springmvc-异步请求-返回DeferredResult 61.1 DeferredResult 官方文案 61.2 使用 /** * 创建订单加入 订单处理队列 * * @return ...

  2. sql server 交集,差集的用法 (集合运算)

    概述 为什么使用集合运算: 在集合运算中比联接查询和EXISTS/NOT EXISTS更方便. 并集运算(UNION) 并集:两个集合的并集是一个包含集合A和B中所有元素的集合. 在T-SQL中.UN ...

  3. 中检测到有潜在危险的 Request.Form 值。”

    添加富文本时  如果出现" 中检测到有潜在危险的 Request.Form 值.”   却不知道怎么排错时,就在HTML   或Web表格头部添加   ValidateRequest=&qu ...

  4. Laravel Repository Pattern

    Laravel Repository Pattern   The Repository Pattern can be very helpful to you in order to keep your ...

  5. openssl制作双向认证经过验证可行

    openssl制作双向认证经过验证可行 http://www.360doc.com/content/12/0524/15/2150778_213390447.shtml 2012-05-24  履历馆 ...

  6. xhEditor编辑器从word粘贴公式

    我司需要做一个需求,就是使用富文本编辑器时,不要以上传附件的形式上传图片,而是以复制粘贴的形式上传图片. 在网上找了一下,有一个插件支持这个功能. WordPaster 安装方式如下: 直接使用Wor ...

  7. Linux操作系统常用命令合集——第四篇-文件系统权限操作(5个命令)

    1.umask [命令作用] 文件或目录创建时的遮罩码 [命令语法] umask     [选项]    [参数] [常用选项] -p  --输出的权限掩码可直接作为指令来执行 -s  --以符号方式 ...

  8. DOM操作1

    1.DOM文档对象模型:操作页面元素(标签) html文件看成一个文档,把文档看成一个对象 xml也是一种文档,标签自定义,系统不自带标签,偏向于存储数据 2.DOM树:由文档及文档中的所以元素(标签 ...

  9. Educational Codeforces Round 68

    目录 Contest Info Solutions A.Remove a Progression B.Yet Another Crosses Problem C.From S To T D.1-2-K ...

  10. C++类的介绍

    最近在学习SLAM,顺便将C++类的知识复习一下.(其中部分官方定义和程序设计方法来源于西北工业大学魏英老师)   1.类的定义: 是用户自定义的数据类型. C++一个类定义的形式如下: class ...