[react] 举例说明如何在React创建一个事件

[react] 举例说明如何在React创建一个事件

import React, { Component } from 'react';
import ReactDOM from 'react-dom';
var EventEmitter = require('events').EventEmitter;
let emitter = new EventEmitter();class ListItem extends Component {static defaultProps = {checked: false};constructor(props) {super(props);}render () {return (<li><input type="checkbox" checked={this.props.checked} onChange={this.props.onChange} /><span>{this.props.value}</span></li>);}
}class List extends Component {constructor(props) {super(props);this.state = {list: this.props.list.map(entry => ({text: entry.text,checked: entry.checked || false}))};console.log(this.state);}onItemChange (entry) {const { list } = this.state;this.setState({list: list.map(prevEntry => ({text: prevEntry.text,checked: prevEntry.text === entry.text ? !prevEntry.checked : prevEntry.checked}))});//这里触发事件emitter.emit('ItemChange', entry);}render () {return (<div><ul>{this.state.list.map((entry, index) => {return (<ListItemkey={`list - ${index}`}value={entry.text}checked={entry.checked}onChange={this.onItemChange.bind(this, entry)} />);})}</ul></div>);}
}class App extends Component {constructor(props) {super(props);}componentDidMount () {this.itemChange = emitter.addListener('ItemChange', (msg, data) => console.log(msg));//注册事件}componentWillUnmount () {emitter.removeListener(this.itemChange);//取消事件}render () {return (<List list={[{ text: 1 }, { text: 2 }]} />)}
}ReactDOM.render(<App />,document.getElementById('root')
);

  个人简介

我是歌谣,欢迎和大家一起交流前后端知识。放弃很容易,
但坚持一定很酷。欢迎大家一起讨论





主目录

与歌谣一起通关前端面试题

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/404954.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c# 2.0实现摄象头视频采集,拍照,录象

From: http://blog.csdn.net/ysq5202121/article/details/5672291 Camera.cs类文件using System; using System.IO; using System.Drawing.Imaging; using System.Runtime.InteropServices; using System.Drawing; using System.Collections; using System.Data;namespace So…

socket初级使用(客户端)

在国庆这段时间里用零星的一些时间看了一下socket的学习资料&#xff0c;由于笔者偏向学习实用方面的内容&#xff0c;因此此篇文章涉及理论知识较少&#xff0c;主要是以实现思路(怎么做)为主,但在实现之前还是需要了解一些基础的理论知识(如果其中有误请指出) TCP是用socket来…

CRC16循环冗余校验 RTU-MODBUS标准 Linux C

1、概述 CRC16循环冗余校验常用在MODBUS协议中&#xff0c;用于校验报文的完整性。CRC16校验值为uint16_t 无符号整形2字节&#xff0c;在MODBUS协议中&#xff0c;低检验字节在前&#xff0c;高校验字节在后&#xff0c;比如校验结果crc160x1788&#xff0c;则MODBUS中的校验…

第11章 路由器OSPF动态路由配置

实验目标&#xff1a; 一、掌握OSPF协议的配置方法&#xff1b; 二、掌握查看通过动态路由协议OSPF学习产生的路由信息&#xff1b; 三、熟悉广域网线缆连接方式&#xff1b; 技术原理&#xff1a; OSFP开放式最短路径优先协议&#xff0c;是目前网络中最广泛的路由协议之一。属…

Hi3515的开发板 Hi3515 SDK编译出错 提示缺少libpciv.a的解决办法

From: http://zyd87818.blog.163.com/blog/static/17488150120124300261687/ 这是HI3515说明文档的说明 但是我进去编译却通不过&#xff0c;提示错误如下 通过qq群里的好人帮助解决方法如下首先看一下makefile自己看不懂&#xff0c;经高人指点需要修改Makefile.param文件…

[react] React为什么要搞一个Hooks?

[react] React为什么要搞一个Hooks&#xff1f; 动机 Hook 解决了我们五年来编写和维护成千上万的组件时遇到的各种各样看起来不相关的问题。无论你正在学习 React&#xff0c;或每天使用&#xff0c;或者更愿尝试另一个和 React 有相似组件模型的框架&#xff0c;你都可能对这…

有关Botton的用法(二)

关于设置listener监听onClicked事件的步骤分析 Steps: 1.tell android you are interested in listening to a button click 2.bring your xml button inside java 3.tell your java button whose responding when its clicked 4.what should happen when button is clicked 1 …

poj1222

题意&#xff1a;一个01矩阵&#xff0c;表示灯的亮灭状态&#xff0c;每次操作可以改变一个十字形状内的五个灯的状态。问能否将所有灯熄灭。 分析&#xff1a;高斯消元法 对于每个灯的两灭有影响的开关就是它附近十字形内的五个开关。所以对于每个灯可以列一个方程&#xff0…

[react] React Hooks帮我们解决了哪些问题?

[react] React Hooks帮我们解决了哪些问题&#xff1f; React hooks help use get rid of js class and all trouble with this pointer. 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌…

李秋红130705010066

3-9、没有冗余度的信源还能不能压缩&#xff1f;为什么&#xff1f; 解答&#xff1a;可以压缩。这种情况下&#xff0c;不能使用无损压缩&#xff0c;但可以使用有损压缩。 3-10、不相关的信源还能不能压缩&#xff1f;为什么&#xff1f; 解答&#xff1a;可以压缩。对于不相…

iphone开发我的新浪微博客户端-用户登录准备篇(1.1)

首先说一下我这个的实现思路&#xff0c;登录支持多个账号&#xff0c;也就是说可以保存多个微博账号登录的时候选择其中一个登录。多个账号信息保存在sqlite的数据库中&#xff0c; 每一个账号信息就是一条记录, 当用户启动微博客户端的时候去取保存在sqlite数据库中的账号记录…

基于密度的异常值检测方法整理

基于密度的异常值检测方法的原理认为正常样本点所处的类簇密度要高于异常点样本所处的类簇密度。为解决实际异常值检测情况 中出现的问题&#xff0c;有一种基于局部异常因子 LOF 方法。

[react] 有在项目中使用过Antd吗?说说它的好处

[react] 有在项目中使用过Antd吗&#xff1f;说说它的好处 They gave every user a big surprise on Christmas Holiday. 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端…

TCP的流模式与UDP的报文模式对比

1 案例背景 在学习TCP-IP协议详解卷一时&#xff0c;读到介绍TCP协议的部分&#xff0c;发现TCP的首部是没有报文总长度字段的&#xff0c;而在UDP中是有的&#xff0c;对这个问题的思考引出了两者之间的区别。 2 案例分析 TCP报文的格式&#xff1a; TCP首部的格式&a…

GWT 入门介绍

From: http://blog.csdn.net/struts2/article/details/1758122 GWT 入门介绍 GWT使用JSON格式的数据通讯 GWT是 Google Web Toolkit的简称。 GWT是一个以Java语言为工具&#xff0c;以类似Swing的方式编写UI组件&#xff0c;之后通过GWT Compiler编译 为JavaScritp和HTM…

SQL Server 2008空间数据应用系列十一:Bing Maps中呈现GeoRSS订阅的空间数据

友情提示&#xff0c;您阅读本篇博文的先决条件如下&#xff1a; 1、本文示例基于Microsoft SQL Server 2008 R2调测。 2、具备 Transact-SQL 编程经验和使用 SQL Server Management Studio 的经验。 3、熟悉或了解Microsoft SQL Server 2008中的空间数据类型。 4、具备相应&am…

聚类算法的分类整理

1、基于划分的聚类算法 基于划分的聚类算法 主要通过聚类中心的迭代重置&#xff0c;直到达到“簇内点足够近&#xff0c;簇间点足够远”的目标效果&#xff0c;完成样本集的最优化分。其算法优点是时间、空间复杂度低&#xff0c;可以处理大规模数据集。缺点包括容易陷入局部…

[react] 为什么标签里的for要写成htmlFor呢?

[react] 为什么标签里的for要写成htmlFor呢&#xff1f; 为了区别和html自身标签中属性 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

minGW64安装和使用 极简教程

1、下载minGW64 官网下载&#xff1a;https://sourceforge.net/projects/mingw-w64/files/mingw-w64/mingw-w64-release/我的FTP&#xff1a;a、minGW64 install.exe b、解压免安装版 2、解压 3、添加环境变量 4、CMD 运行gcc 安装完成。 5、使用minGW编译C源码 6、运行