文章详情页
javascript - React中组件绑定this
浏览:178日期:2023-05-05 18:28:44
问题描述

<button onClick={this.handleEvent}> //这里的this是toggle组件 为什么还需要在组件里绑定这个函数的this {this.state.isToggleOn === true ? ’on’ : ’off’}</button>
想不明白这里的this绑定
问题解答
回答1:因为在class中声明函数,并不会自动绑定this对象
所以,你在onClick={this.handleEvent}的时候,分解成两步你就懂了:
let handleEvent = this.handleEvent;...onClick={handleEvent}...
所以,onClick调用的时候,handleEvent中的this会是undefined(根据文档)
所以,你需要bind一下, 那么里面的this就是当前组件啦。
还有一种方便的写法,就是用箭头函数声明:
handleEvent = (e)=>{}render(){ ...onClick={this.handleEvent}...}回答2:
因为handleEvent中this.setState...的this并没有绑定this
可以采用箭头函数的语法糖来绑定this
handleEvent = () => { this.setState...}
标签:
JavaScript
相关文章:
1. javascript - 项目用IE浏览器打开修改前端内容,后台数据修改了,但是前端页面内容不变,用谷歌浏览器测试前端页面可以刷新,求大神解决。2. android - java tm platform se binary 占用很多内存3. javascript - 关于js高级程序中的问题4. thinkPHP5中获取数据库数据后默认选中下拉框的值,传递到后台消失不见。有图有代码,希望有人帮忙5. mysql 怎么做到update只更新一行数据?6. Java中的多人游戏。将客户端(玩家)连接到其他客户端创建的游戏7. javascript - CSS图片轮播显示问题8. datetime - Python如何获取当前时间9. jpa mysql 如何id自增初始值?10. 现在大家是用Mysql还是mariaDb?
排行榜

网公网安备