react 做的简易todolist

首先要有一定的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;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容