在线等,挺急的!一个黑科技版的this指向问题

偶然间见到这么一段代码,但有点困惑
functionTest(){
Test.prototype.add=num=>{
this.number=num
}
Test.prototype.number=0
}
t1=newTest()
t2=newTest()
t1.add(12)
vara=t1.number
varb=t2.number
console.log(a,b)//=>0,12
最后的结果是0,12为什么这里的结果不是12,12,或是12,0
我大概有点思路,但不敢肯定,故在此恳请各位大佬予以指导我的思路是this.numberthis在此时指向了t2。
最后,希望大佬予以解决,给点详细的思路,谢谢了!
一只萌萌小番薯
浏览 275回答 2
2回答

繁花不似锦

每实例化一次Test,Test.prototype.add都会被重新赋值一次,并且赋值的函数为箭头函数,箭头函数无自身的上下文,其中的this指向Test上下文中的this,即每次实例化的实例对象。

侃侃尔雅

functionTest(){Test.prototype.add=num=>{this.number=num}Test.prototype.number=0}t1=newTest();t2=newTest();t1.add(12)此时:t1:{number:12,add:num=>{}}t2:{number:0,add:num=>{}}这是2个对象了,没有关系,如果输出Test.prototype,依然是0,但两个对象t1t2没有关系的
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript