文章详情页
javascript - React中组件绑定this
浏览:113日期: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. android - 启动模拟器的,报“Could not automatically detect an ADB binary……”,要怎么解决?2. 如何分别在Windows下用Winform项模板+C#,在MacOSX下用Cocos Application项目模板+Objective-C实现一个制作游戏的空的黑窗口?3. python - TypeError: tryMsgcode() takes exactly 2 arguments (0 given)4. javascript - 关于json中获取多个key-value对中多层嵌套key的name5. 关于docker下的nginx压力测试6. docker安装后出现Cannot connect to the Docker daemon.7. android clickablespan获取选中内容8. javascript - 最终生成的jsBundle文件压缩问题9. angular.js - angularjs的自定义过滤器如何给文字加颜色?10. node.js - 如何在服务器部署vuejs项目?
排行榜
