位置: 编程技术 - 正文
推荐整理分享javascript this详细介绍(彻底弄懂js中的this指向),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:js function(this),彻底弄懂js中的this指向,javascript的this用法,js中this的作用,如何理解javascript中的this,javascript的this用法,javascript的this用法,如何理解javascript中的this,内容如对您有帮助,希望把文章链接给更多的朋友!
this的值是在运行时确定的
JS中的this究竟代表什么,这是在程序运行时根据上下文环境确定,可以分为以下几种情况。
1. 全局作用域中的this
在全局作用域中,this指向window对象。
在全局作用域中执行var x=5,其实是为window对象创建一个属性x,并令其等于5。
若定义变量时不加var,JS会认为该变量为全局变量,会将其当作window对象的属性。
2. 函数中的this
JS中函数有两种,直接调用的函数称为普通函数,通过new创建对象的函数称为构造函数。
2.1 构造函数中的this
构造函数的this指向它所创建的对象,如:
2.2 普通函数中的this
普通函数的this指向window对象。 若上述例子,直接执行Perosn函数,则其中this代表window对象,因此该函数执行后会创建一个全局的name。
3. 对象中的this
对象中的this指向当前对象,如:
上述代码中this指向函数getName所属的对象。
但是,如果一个对象的函数中又嵌套了一个函数,这个函数的this指向的却是window,而并不是其外层的对象。
上述示例中,person对象中有一个getName函数,而getName函数内部又有一个函数,这个函数内部的this指向window对象,而非person对象,这是JS的一个bug!一般作如下处理,规避这个bug:
我们在person对象的第一层函数中,将this赋给局部变量that,然后在第二层函数中使用that,此时that指向person对象,可对person的属性进行操作。
注意:若将一个对象中的函数赋给一个变量后,再通过该变量调用这个函数,此时该函数中的this指向window,而非该对象,如下所示:
4. 用call和apply函数给this开挂
这两个函数都能手动指定被调用函数内部的this指向哪个对象。
apply用法
对象A.函数名.apply(对象B, 参数列表); 当对象B作为apply的第一个参数传给apply时,对象A的函数中this就指向了对象B,此时对象A的该函数对this的操作将会作用在对象B上,由此实现了用对象A去调用对象B的函数。
标签: 彻底弄懂js中的this指向
本文链接地址:https://www.jiuchutong.com/biancheng/373590.html 转载请保留说明!友情链接: 武汉网站建设