文章详情页
javascript - React中组件绑定this
浏览:243日期: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. notepad+编写的html,打开就是这样了。为什么,大神们2. python3.x - python连oanda的模拟交易api获取json问题第五问3. phpstudy8.1支持win11系统吗?4. Mysql取下一条记录5. javascript 如何下载一个excel文件 ?6. Chrome-org.openqa.selenium.WebDriverException:未知错误:无法在driver.manage()window()maximize();处获得自动化扩展7. 求助一个Android控件名称8. mysql federated引擎无法开启9. sublime text 3不支持python的input吗10. python对8000行csv添加列
排行榜

网公网安备