摘要:而中在运行期进行绑定的,这是中关键字具备多重含义的本质原因。那么可解释为函数调用是用进行调用的么这个明显不是,进入否分支,即函数是否用进行调用函数是用进行调用的,即进入是分支,即这里的指向中之前的对象所以
1.前言
在主流的面向对象的语言中(例如Java,C#等),this 含义是明确且具体的,即指向当前对象,一般在编译期绑定。而 JavaScript 中this 在运行期进行绑定的,这是JavaScript 中this 关键字具备多重含义的本质原因。
JavaScript 中的 this 可以是全局对象、当前对象或者任意对象,这完全取决于函数的调用方式。
例1.
var point = { x : 0, y : 0, moveTo : function(x, y) { this.x = this.x + x; this.y = this.y + y; } }; point.moveTo(1,1); //this 绑定到当前对象,即point对象
图解point.moveTo函数的this指向什么的解析图如下图所示:
例2:
function func(x) { this.x = x; } func(5); //this是全局对象window,x为全局变量 x;//x => 5
图解func函数的this指向什么的解析图如下图所示:
例3:
var point = { x : 0, y : 0, moveTo : function(x, y) { // 内部函数 var moveX = function(x) { this.x = x;//this 指向什么?window }; // 内部函数 var moveY = function(y) { this.y = y;//this 指向什么?window }; moveX(x); moveY(y); } }; point.moveTo(1,1); point.x; //=>0 point.y; //=>0 x; //=>1 y; //=>1
说明:
point.moveTo(1,1)函数实际内部调用的是moveX()和moveY()函数, moveX()函数内部的this在 “JavaScript this决策树“中进行判定的过程是这样的:
1)moveX(1)函数调用是用new进行调用的么?这个明显不是,进入“否”分支,即函数是否用dot(.)进行调用?;
2)moveX(1)函数不是用dot(.)进行调用的,即进入“否”分支,即这里的this指向全局变量window,那么this.x实际上就是window.x;
例4.作为构造函数调用的例子:
function Point(x,y){ this.x = x; // this ? this.y = y; // this ? } var np=new Point(1,1); np.x;//1 var p=Point(2,2); p.x;//error, p是一个空对象undefined window.x;//2
说明:
Point(1,1)函数在var np=new Point(1,1)中的this在 “JavaScript this决策树“中进行判定的过程是这样的:
1)var np=new Point(1,1)调用是用new进行调用的么?这个明显是,进入“是”分支,即this指向np;
2)那么this.x=1,即np.x=1;
Point(2,2)函数在var p= Point(2,2)中的this在 “JavaScript this决策树“中进行判定的过程是这样的:
1)var p= Point(2,2)调用是用new进行调用的么?这个明显不是,进入“否”分支,即函数是否用dot(.)进行调用?;
2)Point(2,2)函数不是用dot(.)进行调用的?判定为否,即进入“否”分支,即这里的this指向全局变量window,那么this.x实际上就是window.x;
3)this.x=2即window.x=2.
例5.用call 和apply进行调用的例子:
function Point(x, y){ this.x = x; this.y = y; this.moveTo = function(x, y){ this.x = x; this.y = y; }; } var p1 = new Point(0, 0); var p2 = {x: 0, y: 0}; p1.moveTo.apply(p2, [10, 10]);//apply实际上为p2.moveTo(10,10) p2.x//10
说明:
apply 和 call 这两个方法允许切换函数执行的上下文环境(context),即 this 绑定的对象。
p1.moveTo.apply(p2,[10,10])实际上是p2.moveTo(10,10)。那么p2.moveTo(10,10)可解释为:
1)p2.moveTo(10,10)函数调用是用new进行调用的么?这个明显不是,进入“否”分支,即函数是否用dot(.)进行调用?;
2)p2.moveTo(10,10)函数是用dot(.)进行调用的,即进入“是”分支,即这里的this指向p2.moveTo(10,10)中.之前的对象p2,所以p2.x=10;
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/78973.html
摘要:当碰到时呵呵再看一个呵呵再来呵呵呵呵呵呵呵呵什么意思呢如果返回值是一个对象,那么指向的是构造函数的实例但是并没有被返回,如果返回值不是一个对象那么还是指向构造函数创建的实例。 为什么要学习this?如果你学过面向对象编程,那你肯定知道干什么用的,如果你没有学过,那么暂时可以不用看这篇文章,当然如果你有兴趣也可以看看,毕竟这是js中必须要掌握的东西。 1. this指向调用他的对象 首先...
摘要:首先,必须搞清楚在里面,函数的几种调用方式普通函数调用作为方法来调用作为构造函数来调用使用方法来调用方法箭头函数但是不管函数是按哪种方法来调用的,请记住一点谁调用这个函数或方法关键字就指向谁。 本文主要解释在JS里面this关键字的指向问题(在浏览器环境下)。 首先,必须搞清楚在JS里面,函数的几种调用方式: 普通函数调用 作为方法来调用 作为构造函数来调用 使用apply/call...
摘要:函数的几种调用方式普通函数调用作为方法来调用作为构造函数来调用使用方法来调用方法箭头函数但是不管函数是按哪种方法来调用的,都需要记住一点谁调用这个函数或方法关键字就指向谁。作为构造函数来调用构造函数出来的实例,指向这个实例对象。 首先,了解一下this关键字。this关键字就涉及到函数调用的内容。函数的几种调用方式: 1 普通函数调用2 作为方法来调用3 作为构造函数来调用4 使用ap...
摘要:出于这个原因,该函数返回的,所以在这里指的是,所以返回的是第一个说明关键字通常在对象的构造函数中使用,用来引用对象。重写无法重写,因为它是一个关键字。结论,表示当前的上下文对象是一个对象,可以调用对象所拥有的属性,方法。 在《javaScript语言精粹》这本书中,把 this 出现的场景分为四类,简单的说就是: 有对象就指向调用对象 没调用对象就指向全局对象 用new构造就指向新对...
摘要:面向对象编程指向一。总结的值要等到代码真正执行是才能确定。,调用,只想我们指定的对象后续更新。对象调用,如执行,指向。默认的,指向全局变量。特殊虽然也是对象,但是在这里还是指向那个函数的实例,因为比较特殊。 面向对象编程 --- this指向 一。首先:, this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最...
阅读 2278·2021-11-11 16:54
阅读 2538·2021-09-26 09:47
阅读 3922·2021-09-08 09:36
阅读 2687·2021-07-25 21:37
阅读 882·2019-08-30 15:54
阅读 2515·2019-08-30 14:22
阅读 3225·2019-08-30 13:57
阅读 2474·2019-08-29 17:17