React16.4 快速上手 --- (1)编写todolist功能以及新增列表项

import React from 'react';

class ToDoList extends React.Component{
    constructor(props){
        super(props);
        this.state = {
            list: [],
            inputValue: '',
        };
    }

    handleInputChange(e){
      this.setState({
          inputValue: e.target.value
      })
      // console.log(e.target.value)
    }

    handleBtnClick(){
        this.setState({
                list: [...this.state.list, this.state.inputValue],
                inputValue: '',
            })
    }

    render() {
        return (
            <div>
                <div>
                    <input value={this.state.inputValue} onChange={this.handleInputChange.bind(this)}/>  // step1
                    <button onClick={this.handleBtnClick.bind(this)}>add</button> // step2
                </div>
                <ul>
                    {this.state.list.map((item, index)=> {
                        return <li key={index}>{item}</li>
                    })} // step3
                </ul>
            </div>
        );
}
}
export default ToDoList;


实现步骤:

step1 : 在输入框内输入文字,触发onChange事件,调用与ToDoList组件绑定的handleInputChange方法,更新this.state.inputValue的值,输入框内value值等于当前this.state.inputValue的值,显示在输入框中;

step2: 点击名为add的按钮,触发onClick事件,调用与ToDoList组件绑定的handleBtnClick方法, 在this.state.list中增加this.state.inputValue的值,将新的list中的所有数据显示在无序列表中,再更新this.state.inputValue的值为'',对step1中显示在输入框中的文字做清除动作;

step3: map()方法遍历list中的数据,显示在无序列表中,渲染到页面

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值