热门标签 | 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。

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



推荐阅读
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社区 版权所有