4. react 基础 - 编写 todoList 功能
编写 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 功能的更多相关文章
- 14. react 基础 redux 的编写 TodoList 功能
1. 安装 redux 监听工具 ( 需要翻墙 ) 打开 谷歌商店 搜索 redux devtool 安装第一个即可 2. 安装 redux yarn add redux 3. 创建 一个 store ...
- (三)React基础
3-1 使用React编写TodoList功能 import { Fragment} from ‘react’ Fragment是占位符 用于替代最外层div元素, 防止生成的元素会有两层div嵌套这 ...
- 13. react 基础 redux 的基本介绍 及 用 antd 编写 TodoList 的样式
1. redux 简述 当 store 内的 数据进行变更的时候 多个组件感知到 store 内的数据变化 将会被自动更新 2. redux 工作流 Store 代表数据存储 (例如: 图书馆管理 ...
- 18 react react-redux 的编写 TodoList
1. 安装 react-redux yarn add react-redux 2. react-redux 编写 TodoList 使所有子组件 都能使用 store #index.js import ...
- React Native移动框架功能研究
React Native移动框架功能研究 此篇只研究React Native框架的功能. 一.React Natvie是什么 React Native是使用React(或者说JS)来开发原生APP的框 ...
- HTML&CSS基础-html注释功能
HTML&CSS基础-html注释功能 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是HTML(Hypertext Markup Language) 超文本标记 ...
- 5. react 基础 - 组件拆分 和 组件传值
1.将 todoList 进行拆分 创建 编写TodoList.js import React, {Component, Fragment} from 'react';import TodoItem ...
- react基础(1)
在 react入门系列 里面,介绍了一些react的基础知识,在react基础部分,会结合手脚架工具进行更多的总结. 关于webpack我在这里就不讲解了,有需要的小伙伴可以自己去百度一下学习资料,我 ...
- 利用React/anu编写一个弹出层
本文将一步步介绍如何使用React或anu创建 一个弹出层. React时代,代码都是要经过编译的,我们很多时间都耗在babel与webpack上.因此本文也介绍如何玩webpack与babel. 我 ...
随机推荐
- 小米百元NFC智能神器来了:必成爆款!
6月14日,小米手环4全渠道首卖,其中电商平台今日10:00开卖,线下小米之家需要顾客持本人身份证限购一台. 首销结束后,米家官微宣布,小米手环4下一轮开售时间在6月18日上午10:00,届时小米手环 ...
- asp.net mvc邮箱激活
1.发送邮件 public ActionResult SendEmail() { var member = dbSession.MemberRepository.LoadEntities(p => ...
- a标签的超链接提交form表单
<form action="/home/search" method="get" id="search_form"><di ...
- 破解centos7 密码
1.在CentOS7的启动选项,按“e”选择编辑启动选项2.进入下图画面,点下箭头直到看到“linux162174542514”,按end键跳到行尾3.在行尾加上“rd.break”,并敲击键盘“ct ...
- DEDECMS打开网站后台系统首页卡解决方法
找到根目录下(一般是dede) templets文件夹下找到index_body.htm文件,将第25行至第41行部分注释或删除 保存文件,然后再打开后台,就不会有这个问题了.
- golang用slice、list当queue
背景 golang没有queue这种类型,不过可以用slice.list模拟 slice当queue 声明队列 var queue []int 入队一个元素: queue = append(queue ...
- Ubuntu 14.04 安装 Dash to Dock
每次打开或选择一个已经打开的应用都要把鼠标指到左上角,相当费事. Ubuntu 14.04 GNOME自带 Tweaks (系统中名为:优化工具),可以使界面如Windows般(最小化.最大化.底部任 ...
- Meeloun教你如何正式切入Essay写作话题
很多同学在Essay写作过程中会发现:如果题目问到解决办法,写来写去,都是政府要颁布政策,人们要提高意识,感觉一点新意也没有.怎么样更好地切合不同的话题,想到最合适的解决办法呢?今天小编为你奉上更多处 ...
- TD信息通(无课表)使用体验
首先,在注册账户的时候,TD信息通还是比较严谨的.用户名字符数.密码字符数.邮箱格式等都有要求,我认为,这对App的长远发展来说,是很重要的一个细节.而且,在登陆之前,会有一项关于是否自动登陆的选择, ...
- JavaScript的运算符、条件判断、循环、类型转换(9.25 第十一天)
JS的运算符 加 + 减 - 乘 * 除 / 取余 % 自增 ++ 自减 -- 赋值运算符 a=3 a+=3 a=a=3 a-=3 a=a-3 a*=3 a=a*2 a/=3 a=a/3 ...