两个this各自指的是什么?
1.这里2个this不是指向同一个对象,请问各自指的是什么?class组件内(排除render(){}里面的JSX),默认是没有this的是吗?那么组件实例用什么代表呢?render(){}内jsx的this指的是谁呢?2.render()方法里面的jsx 和整个class 组件最终有什么区别?
3.{} 落地是什么意思?是指的渲染完成吗?为何落地后能和class的this是同一个?
回复
1个回答

test
2024-07-18
函数中的this指向不是看它写在哪,而是要看函数被谁调用,render中的this就是直向组件本身,onclick={this.addNum}
的写法是将addNum取值后再赋值给onClick,那么onClick执行调用addNum的时候,addNum里的this就指向button元素,onclick={() => this.addNum}
的写法是将箭头函数赋值给onClick,箭头函数没有this,他的this来自父作用域,也就是render,指向组件,并且addNum是被this调用,所以addNum里的this也指向组件
回复

适合作为回答的
- 经过验证的有效解决办法
- 自己的经验指引,对解决问题有帮助
- 遵循 Markdown 语法排版,代码语义正确
不该作为回答的
- 询问内容细节或回复楼层
- 与题目无关的内容
- “赞”“顶”“同问”“看手册”“解决了没”等毫无意义的内容