所属分类:web前端开发
写法:1、用“onClick={this.handleClick}”;2、用“onClick={this.handleClick.bind(this)}”;3、用“{(params)=>this.handleClick(params)}”。
前端(vue)入门到精通课程:进入学习
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用
本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。
开门见山,先直接给出为一个button添加一个事件的正确写法:
为一个button添加一个onclick事件的正确写法
// handleClick用 <箭头函数> 定义
onClick = { this.handleClick }
// handleClick用箭头函数定义时,为onClick添加事件应该这么写:<Button onClick = { this.handleClick }></Button>
登录后复制
handleClick这么定义:
handleClick = () => { // do something here};
登录后复制
或
// handleClick用 (普通函数) 定义
onClick = { this.handleClick.bind(this) }
// handleClick用普通函数定义时,为onClick添加事件应该这么写:<Button onClick = { this.handleClick.bind(this) }></Button>
登录后复制
handleClick这么定义:
handleClick () { // do something here }
登录后复制
// handleClick用 <箭头函数>/(普通函数) 定义都可以
onClick = { (params) => this.handleClick(params) }
// handleClick可以是箭头函数,也可以是普通函数<Button onClick = { (params) => this.handleClick(params) }></Button>
登录后复制
接下来分析一下为什么这样写是正确的:
理解这个问题,带着下面这几句话去理解:
箭头函数,没有自己的this,所以它的this是 : 定义时上下文 的this
普通函数,有自己的this,所以它的this是:执行时上下文的this
先来看第一种写法:
下面给出的代码为:为一个按钮添加onclick事件(一个完整的jsx)
// examplePage.jsximport React from 'react';import { Button } from 'antd';class examplePage extends React.Component {
// 2. 定义handleClick事件
handleClick = () => {
console.log(this); //3. this指向examplePage
}
render() {
return (
<p>
// 1. 为onClick绑定 handleClick事件处理函数
<Button onClick = { this.handleClick }>click me</Button>
</p>
)
}}export default examplePage;
登录后复制
点击按钮,打印出指向examplePage的this:
this: examplePage {props: Object, context: {}, refs: {}, updater: Object, state: {}, …}
分析:
先来看,如果不用bind(this),console.log(this)会输出什么:
// examplePage.jsximport React from 'react';import { Button } from 'antd';class examplePage extends React.Component {
// 2. !将箭头函数改为普通函数
handleClick () {
console.log(this); // 3. this 为 undefined
}
render() {
return (
<p>
// 1. 为onClick绑定 handleClick事件处理函数
<Button onClick = { this.handleClick }>click me</Button>
</p>
)
}}export default examplePage;
登录后复制
点击按钮,打印出this:
this: undefined
分析:
注:在严格版中,默认的this不再是window,而是undefined
Module code is always strict mode code.
All parts of a ClassDeclaration or ClassExpression are strict mode code.
因此需要用bind来改变this指向,即:
render() {
return (
<p>
// 用bind改变this指向
<Button onClick = { this.handleClick.bind(this) }>click me</Button>
</p>
)}
登录后复制
分析:
理解了上面两个,最后一个就很好理解了:
render() {
return (
<p>
// 通过箭头函数传参
<Button onClick = { (params) => this.handleClick(params) }></Button>
</p>
)}
登录后复制
分析:
那么,不传参的时候,就这么写:
<Button onClick = { () => this.handleClick() }></Button>
登录后复制
但这是不可行的,因为react会直接解析()=> this.handleClick(), handleClick会被调用,相当于onClick = “调用handleClick的结果”
所以,不传参数的时候只能这么写:
<Button onClick = { this.handleClick }></Button>
登录后复制
总结
开头的三个问题可以得到回答
//定义handleClick事件
handleClick = () => {
// do something here
};
//为onClick绑定handleClick事件处理函数
<Button onClick = {this.handleClick}></Button> // 不传参
<Button onClick = {(param) => this.handleClick(param) }></Button> // 传参
登录后复制
推荐学习:《react视频教程》
以上就是react点击事件的几种写法是什么的详细内容,更多请关注zzsucai.com其它相关文章!