热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

appcrash事件怎么解决_React实战实现评分小组的必备武器:React事件(5)

网页是组件构成的,组件是一系列标签形成的单一功能。所以考虑组件无非也就三件事,结构、表现、和行为。结构JSX搞定了(当然JSX不仅仅干这个

网页是组件构成的,组件是一系列标签形成的单一功能。所以考虑组件无非也就三件事,结构、表现、和行为。结构JSX搞定了(当然JSX不仅仅干这个),表现是CSS的事儿,我们重点说下行为,也就是事件和钩子。

事件好说,就是户干了啥事儿,然后有什么样的相应。钩子就是在组件怎么样的时候,干什么事儿。

本文先说事件,因为这个简单的让人发指,钩子用到了我们再说。

事件还是老话,你把原生组件我讲那篇文章看懂了,react就很轻松了,我们先走起一个例子。

大家可以直接使用我准备好的起始文件,替换你的src整个文件夹就行。

56acaad9a258fb465492c9ecb1bc20f6.png

地址:https://github.com/leolau2012/react-basic-tutorial.git

React中事件的写法

先别管别的,我们现在RatingStar.js里面扔进去,以下:

import React, { Component } from 'react'
import './style.css'
class RatingStar extends Component {constructor(props) {super(props)this.state = {score: 0}}handleClick(ev) {console.log(ev.target);}render() {return (

4分
);}
}

export default RatingStar;

这里要注意两点:

1.onClick = {this.handleClick} 这里的事件都要加on而且Click要大写

2.this.handleClick 需被单大括号包裹

this的问题

说重点了,但是往回看最开始的例子大家就知道代码是这样的:

handleClick(ev) {this.setState({score: Number(ev.target.dataset.index) + 1});
}

但是,我们加上去以后居然报错了,

ea3c8bea52297f51dacf51eb47c00f99.png

我们先看一眼this是谁,

e90d2e2e7a089c2e503e1923a47a785f.png
695ba34c7eacacbb6741bd6407cac5cb.gif

大家先不用急,容我慢慢解释。

9b8b93b43dd1ec1b5e23c3bd80145879.png

下面就是最重要的一个东西 -关于组件里面的this问题。

一般在某个类的实例方法里面的 this 指的是这个实例本身。但是在上面我们把 this 打印出来,你会看到 this 是undefined。

这是因为 React.js 调用你所传给它的方法的时候,并不是通过对象方法的方式调用(this.handleClick),而是直接通过函数调用 handleClick所以事件监听函数内并不能通过 this 获取到实例。而严格模式下直接全局调用一个函数,它的this是undefined。这里注意你可以不懂我说的上面这些话,但是你会解决就好了。这个在我们原生js组件又遇到过这个情况说后面解释。这里我们解释了。

解决this的指向

解决方案也简单:

handleClick = (ev)=> {console.log(this);
}

这样就可以了,很多人会用bind 矫正this 我不建议,尽量大家多用箭头函数。

最终代码:

import React, { Component } from 'react'
import './style.css'
class RatingStar extends Component {constructor(props) {super(props)this.state = {score: 0}}handleClick = (ev)=> {console.log(this.setState);this.setState({score: Number(ev.target.dataset.index) + 1});}render() {return (

4分
);}
}

export default RatingStar;

最终大家会发现setState就有了,而且事件也好了。这篇文章我们讲事件怎么用,下篇我们说组件的 state 和 setState

结语:

1.通过onClick事件在React中的使用,举一反三使用 React.js 提供了一系列的 on* 事件。

2.this调用不加括号,class变成className。

额外:将代码下载下来注意组件的组织。



推荐阅读
  • 本文讨论了将HashRouter改为Router后,页面全部变为空白页且没有报错的问题。作者提到了在实际部署中需要在服务端进行配置以避免刷新404的问题,并分享了route/index.js中hash模式的配置。文章还提到了在vueJs项目中遇到过类似的问题。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • PHP反射API的功能和用途详解
    本文详细介绍了PHP反射API的功能和用途,包括动态获取信息和调用对象方法的功能,以及自动加载插件、生成文档、扩充PHP语言等用途。通过反射API,可以获取类的元数据,创建类的实例,调用方法,传递参数,动态调用类的静态方法等。PHP反射API是一种内建的OOP技术扩展,通过使用Reflection、ReflectionClass和ReflectionMethod等类,可以帮助我们分析其他类、接口、方法、属性和扩展。 ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 本文介绍了如何使用vue-awesome-swiper组件,包括在main.js中引入和使用swiper和swiperSlide组件,以及设置options和ref属性。同时还介绍了如何在模板中使用swiper和swiperSlide组件,并展示了如何通过循环渲染swipes数组中的数据,并使用picUrl属性显示图片。最后还介绍了如何添加分页器。 ... [详细]
  • 本文介绍了如何使用elementui分页组件进行分页功能的改写,只需一行代码即可调用。通过封装分页组件,避免在每个页面都写跳转请求的重复代码。详细的代码示例和使用方法在正文中给出。 ... [详细]
  • VueCLI多页分目录打包的步骤记录
    本文介绍了使用VueCLI进行多页分目录打包的步骤,包括页面目录结构、安装依赖、获取Vue CLI需要的多页对象等内容。同时还提供了自定义不同模块页面标题的方法。 ... [详细]
  • node.jsrequire和ES6导入导出的区别原 ... [详细]
author-avatar
159dzhqian449_734
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有