JavaScript中this指向问题如何深入解析和全面理解?
- 内容介绍
- 文章标签
- 相关推荐
本文共计449个文字,预计阅读时间需要2分钟。
在函数定义时,`this`的指向是不确定的,只有在函数执行时才能确定它指向的对象。实际上,`this`的最终指向是调用它的那个对象,也就是说,最后一次调用`this`的对象决定了它的指向。
this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象
this永远指向的是最后调用它的对象,也就是看它执行的时候是谁调用的
普通函数中的this指向:
情况1:如果一个函数中有this,但是它没有被上一级的对象所调用,那么this指向的就是window,这里需要说明的是在js的严格版中this指向的不是window,但是我们这里不探讨严格版的问题,你想了解可以自行上网查找。
情况2:如果一个函数中有this,这个函数有被上一级的对象所调用,那么this指向的就是上一级的对象。
情况3:如果一个函数中有this,这个函数中包含多个对象,尽管这个函数是被最外层的对象所调用,this指向的也只是它上一级的对象
构造函数中的this指向:
function Fn(){ this.title= "你好"; } var a = new Fn(); console.log(a.title); //你好
首先new关键字会创建一个空的对象,然后会自动调用一个函数apply方法,将this指向这个空对象,这样的话函数内部的this就会被这个空的对象替代。
当构造函数的this碰到return时:
如果返回值是一个对象,那么this指向的就是那个返回的对象,如果返回值不是一个对象那么this还是指向函数的实例。
如果返回值是null, null也是对象,但是在这里this还是指向那个函数的实例,因为null比较特殊。
以上就是本次介绍的全部知识点内容,感谢大家对易盾网络的支持。
本文共计449个文字,预计阅读时间需要2分钟。
在函数定义时,`this`的指向是不确定的,只有在函数执行时才能确定它指向的对象。实际上,`this`的最终指向是调用它的那个对象,也就是说,最后一次调用`this`的对象决定了它的指向。
this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象
this永远指向的是最后调用它的对象,也就是看它执行的时候是谁调用的
普通函数中的this指向:
情况1:如果一个函数中有this,但是它没有被上一级的对象所调用,那么this指向的就是window,这里需要说明的是在js的严格版中this指向的不是window,但是我们这里不探讨严格版的问题,你想了解可以自行上网查找。
情况2:如果一个函数中有this,这个函数有被上一级的对象所调用,那么this指向的就是上一级的对象。
情况3:如果一个函数中有this,这个函数中包含多个对象,尽管这个函数是被最外层的对象所调用,this指向的也只是它上一级的对象
构造函数中的this指向:
function Fn(){ this.title= "你好"; } var a = new Fn(); console.log(a.title); //你好
首先new关键字会创建一个空的对象,然后会自动调用一个函数apply方法,将this指向这个空对象,这样的话函数内部的this就会被这个空的对象替代。
当构造函数的this碰到return时:
如果返回值是一个对象,那么this指向的就是那个返回的对象,如果返回值不是一个对象那么this还是指向函数的实例。
如果返回值是null, null也是对象,但是在这里this还是指向那个函数的实例,因为null比较特殊。
以上就是本次介绍的全部知识点内容,感谢大家对易盾网络的支持。

