编写 TodoList 功能

  react 入口 js

  #src/index.js

    import React from 'react';

    import ReactDOM from 'react-dom';

    import TodoList from './TodoList'

    ReactDOM.render(<TodoList />, document.getElementById('root'));

  #src/TodoList.js

    // Fragment 为占位符

    import React, { Component , Fragment } from 'react';

    class TodoList extends Component

    {

      render(){

        // 每一个 render 的 标签 只能返回一个标签 其他的都包含在这个标签内

        // 使用 Fragment 能 不然最外层元素 被渲染出来

        return (

          <Fragment>

            <input type='text' /> <button>提交</button>

            <ul><li>吃饭</li><li>睡觉</li><li>打豆豆</li></ul>

          </Fragment>

          );

      }

    }  // 导出 TodoList

    export default TodoList

  //添加 input change 事件

  # todoList.js

    import React, { Component , Fragment } from 'react';

    class TodoList extends Component

    {

      constructor( props ){

        // 必须 调用一次 父类 constructor 完成父类初始化

        super(props)

        //对 需要使用的 数据 进行定义 ( 定义在 this.state 下 )

        this.state = { inputValue: '' }

      }

      render(){

        return (

          <Fragment>

            {/* 定义该 文本框的 值 为 this.state.inputValue , 改变事件为 this.inputChange  并制定 该事件的 this 为 TodoList 这个类 */}

            <input type='text' value={this.state.inputValue}  onChange={this.inputChange.bind(this)} />

              <button>提交</button>

            <ul><li>吃饭</li><li>睡觉</li><li>打豆豆</li></ul>

          </Fragment>

          );

      }

      inputChange(e){

        // 设置 this.state.inputValue 的 值 等于 输入的值

        this.setState( {inputValue: e.target.value} );

      }

    }  // 导出 TodoList

    export default TodoList

  //添加 列表 增加删除功能

    import React, { Component , Fragment } from 'react';

    class TodoList extends Component

    {

      constructor( props ){

        // 必须 调用一次 父类 constructor 完成父类初始化

        super(props)

        //对 需要使用的 数据 进行定义 ( 定义在 this.state 下 )

        this.state = { inputValue: '', list: [] }

      }

      render(){

        return (

          <Fragment>

            {/* 定义该 文本框的 值 为 this.state.inputValue , 改变事件为 this.inputChange  并制定 该事件的 this 为 TodoList 这个类 */}

            <input type='text' value={this.state.inputValue}  onChange={this.inputChange.bind(this)} />

              {/* 添加点击事件 进行数据添加 */}

              <button onClick={this.addClick.bind(this)}>提交</button>

            <ul>

              {

                this.state.list.map((value, index)=>{

                  // 添加删除子项功能

                  return <li key={index} onClick={this.itemDelete.bind(this, index)}>{value}</li>

                })

              }

            </ul>

          </Fragment>

          );

      }

      inputChange(e){

        // 设置 this.state.inputValue 的 值 等于 输入的值

        this.setState( {inputValue: e.target.value} );

      }

      addClick(){

        // 点击之后 添加 输入框内的 value 到

        this.setState({

          list : [...this.state.list, this.state.inputValue],

          inputValue: ''

        })

      }

      itemDelete(index){

        // 根据 immutable 原则 state 内的 数值 不允许我们 做任何改变

        const list = [...this.state.list];

        list.splice(index, 1);

        this.setState({list:list});

      }

    }  // 导出 TodoList

    export default TodoList

4. react 基础 - 编写 todoList 功能的更多相关文章

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

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

  2. (三)React基础

    3-1 使用React编写TodoList功能 import { Fragment} from ‘react’ Fragment是占位符 用于替代最外层div元素, 防止生成的元素会有两层div嵌套这 ...

  3. 13. react 基础 redux 的基本介绍 及 用 antd 编写 TodoList 的样式

    1. redux 简述 当 store 内的 数据进行变更的时候  多个组件感知到 store 内的数据变化 将会被自动更新 2. redux 工作流 Store  代表数据存储 (例如: 图书馆管理 ...

  4. 18 react react-redux 的编写 TodoList

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

  5. React Native移动框架功能研究

    React Native移动框架功能研究 此篇只研究React Native框架的功能. 一.React Natvie是什么 React Native是使用React(或者说JS)来开发原生APP的框 ...

  6. HTML&CSS基础-html注释功能

    HTML&CSS基础-html注释功能 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.  一.什么是HTML(Hypertext Markup Language) 超文本标记 ...

  7. 5. react 基础 - 组件拆分 和 组件传值

    1.将 todoList 进行拆分 创建 编写TodoList.js import React, {Component, Fragment} from 'react';import TodoItem ...

  8. react基础(1)

    在 react入门系列 里面,介绍了一些react的基础知识,在react基础部分,会结合手脚架工具进行更多的总结. 关于webpack我在这里就不讲解了,有需要的小伙伴可以自己去百度一下学习资料,我 ...

  9. 利用React/anu编写一个弹出层

    本文将一步步介绍如何使用React或anu创建 一个弹出层. React时代,代码都是要经过编译的,我们很多时间都耗在babel与webpack上.因此本文也介绍如何玩webpack与babel. 我 ...

随机推荐

  1. JVM--a == (a = b)基于栈的解释器执行过程

    前言 在翻阅ConcurrentLinkedQueue的代码的时候,发现这样一段代码在JDK源码中总是出现. t != (t = tail) 原先总是以为这不就是 t != t ?很是纳闷,遂Demo ...

  2. centos6.7开启linux虚拟机内部错误

    如图 这个需要用管理员身份运行就好了 右键----->以管理员身份打开,正常启动

  3. C++面试常见问题——01预处理与宏定义

    C++面试常见问题--------01预编译和宏的使用 C++预处理器 预处理器是一些指令,它将指示编译器在实际编译之前需要完成的预处理.预处理必须要在对程序进行词法与语义分析.代码生成与优化等通常的 ...

  4. CSS - flex 垂直水平居中

    display: flex; justify-content: center; /* 水平居中 */ align-items: center; /* 垂直居中 */

  5. Exceeded memory limit for $group, but didn't allow external sort. Pass allowDiskUse:true to opt in

    原语句: db.carMongoDTO.aggregate({}}}, {}}}) 报错: Exceeded memory limit for $group, but didn't allow ext ...

  6. systemctl无法停掉keepalived

    这个问题搞了好半天,记录一下,启停都是用的systemctl 起初是测试vip漂移时候发现,主备节点都开启keepalived的状况下,一切正常,主节点的vip也可以访问. 第一次停掉主节点的keep ...

  7. Python安装bs4

    - 需要将pip源设置为国内源,阿里源.豆瓣源.网易源等 - windows (1)打开文件资源管理器(文件夹地址栏中) (2)地址栏上面输入 %appdata% (3)在这里面新建一个文件夹 pip ...

  8. sql select 0 字段 某字段是不在指定的表

    sql select 0 字段 转自   关于 select 语句中 0 某字段名字,的意思是:该某字段是不在指定的表中的,那么如果要在子查询中利用这个指定的表,且带有这个字段,那么就用这个方式来添加 ...

  9. 04-String——课后作业1:字串加密

    题目:请编写一个程序,加密或解密用户输入的英文字串要求设计思想.程序流程图.源代码.结果截图. 程序设计思想:首先由用户选择是加密还是解密,利用String类中的charAt函数依次取出字串中的字符, ...

  10. python的库有多少个?python有多少个模块?

    这里列举了大概500个左右的库: !   Chardet字符编码探测器,可以自动检测文本.网页.xml的编码. colorama主要用来给文本添加各种颜色,并且非常简单易用. Prettytable主 ...