2 shiqianrongcsdn shiqianrongcsdn 于 2015.07.21 21:45 提问

javascript中关于this的绑定问题
 var point = { 
 x : 0, 
 y : 0, 
 moveTo : function(x, y) { 
     // 内部函数
     var moveX = function(x) { 
     this.x = x;//this 绑定到了哪里?
    }; 
    // 内部函数
    var moveY = function(y) { 
    this.y = y;//this 绑定到了哪里?
    }; 

    moveX(x); 
    moveY(y); 
    } 
 }; 
 point.moveTo(1, 1); 
 point.x; //==>0 
 point.y; //==>0 
 x; //==>1 
 y; //==>1

5个回答

CSDNXIAON
CSDNXIAON   2015.07.21 21:48

javascript使用bind()函数绑定this
JavaScript的三种this指向问题
绑定到异步的ObservableCollection [This type of CollectionView does not support changes to its SourceColl]
----------------------同志你好,我是CSDN问答机器人小N,奉组织之命为你提供参考答案,编程尚未成功,同志仍需努力!

bdmh
bdmh   Ds   Rxr 2015.07.21 21:41

就是point对象,你用的是哪个就代表哪个

danielinbiti
danielinbiti   Ds   Rxr 2015.07.21 22:00
 moveTo : function(x, y) { 
// 内部函数
var moveX = function(x) { //这个函数相当于闭包的概念
this.x = x;//this 绑定到了哪里?
}; 
// 内部函数
var moveY = function(y) { 
this.y = y;//this 绑定到了哪里?
};
moveX(x); //这里调用的时候前面是没有对象的,所以该函数内部如果有this,是指window,不是Point
moveY(y); 
} 
}; 
如果要执行当前对象,则需要改一下
moveTo : function(x, y) { 
// 内部函数
this.moveX = function(x) {  //加载this后如果是对象调用moveTo方法,则this指向调用的对象,也就不存在全局变量x了
this.x = x;//this 绑定到了哪里?
}; 
// 内部函数
this.moveY = function(y) { 
this.y = y;//this 绑定到了哪里?
};
this.moveX(x);  
this.moveY(y); 
} 
}; 
strutce
strutce   Ds   Rxr 2015.07.21 22:42

this.y的绑定问题 指的是本页面的y

showbo
showbo   Ds   Rxr 2015.07.22 12:13

那样调用内部的moveX和moveY,this指向的是window对象,并不是point。除非用call/apply改为this的指向

 moveX.call(this,x); 
    moveY.call(this,y); 
showbo
showbo 回复小人物的大世界: danielinbiti 已经说明原因啊,你没有主调对象,moveX(x)相当于window.moveX(x),所以this指向window。你的point.moveTo(1, 1),主调对象时point,所以moveTo方法体内this指向point。你可以什么一个var me=this,在moveX中使用me,而不是this
接近 3 年之前 回复
shiqianrongcsdn
shiqianrongcsdn 我就是不太明白为什么那样的this就指向了window,书上说匿名函数的执行环境具有全局性,因此其this对象通常指向window
接近 3 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
js中this的绑定与丢失
一直以来,this指向的问题都困扰着我,老是不清楚this到底是指向调用对象还是指向window,今天做个了结。 问题又下面这道题引出:var obj={ id:"awesome", cool:function coolFn(){ console.log(this.id); } }; obj.cool()//awesome var id="not awesome"; setTimeout
一个关于VB.NET中TEXTBOX绑定数据库的问题(未完)
一个关于VB.NET中TEXTBOX绑定数据库的问题(未完)
网页中响应ActiveX控件自定义事件
这几天在开发过程中遇到一个问题,即在网页中无法响应ActiveX控件自定义事件。经查资料后,明白ActiveX控件的事件如果要通过JavaScript等脚本语言响应,必须实现IProvideClassInfo或者IProvideClassInfo2接口。因为脚本语言必须通过这个接口获得控件的接口信息。 用MFC ActiveX Control Wizard生成的项目,其接口的实现是通过嵌套类完成
C++中的this与js中的this
在C++中也有this,是一个指针,它在类中,《C++ primer》中说函数接口那也隐藏着this,是一个隐藏的函数参数。 c++中典型的修改this属性就是在类成员函数那修改this指针为常量 比如如下程序: #include using namespace std; class Foo{ public: Foo( ) = default; Foo( int num ):num(
js中this指向问题实例详解
JS中, this的值到底是什么? 几个月之前, 拜读了《javascript语言精髓》, 里面对于这个问题, 做出了很好的解释…JS中, this的值取决于调用的模式, 而JS中共有4中调用模式: 方法调用模式 当一个函数被保存为对象的一个属性时, 我们称它为一个方法, 当一个方法被调用时, this指向该对象, 如: var obj = { value: 1, getValue: func
ES6箭头函数中的this绑定问题
关于this指向问题的讨论一直是学习js不可忽视的重要部分,那些一个又一个围绕this挖的笔试坑,仿佛永远也填不完 var obj={ fn:function(){ console.log(this); } } obj.fn();//object以上这段代码是再浅显不过的this指向问题,也就是谁调用的函数,函数体中的this就指向谁 再看下面这段 var obj={ fn:fun
js算法精度失真问题的解决方案
关于在javascript中数字运算时,精度值问题
JavaScript 事件绑定、事件监听、事件委托
事件绑定:有三种常用的绑定事件的方法: 1、在DOM元素中直接绑定; 2、在 javascript 代码中绑定; 3、绑定事件监听函数。 1、在DOM中直接绑定事件 我们可以在DOM元素上直接绑定事件 例如: function hello(){ alert('hello world!'); }; 2、在
JavaScript,JQuery,Ajax常见问题总结
三、JavaScript/JQuery/Ajax部分 1、请写一段Javascript程序,对以下程序的用户输入日期的有效性进行判断,如果格式错误就提示用户。在程序的恰当位置注明怎样调用你写的程序。日期格式为:年年年年月月日日小时,例如2003010812。 NewPage1   查询日期(yyyymmddhh):   从   到
你不知道的javascript之this的全面解析之绑定规则(一)
1.1 默认绑定首先介绍的是函数调用类型:独立函数调用,在没有其他应用下的默认规则。 首先看以下代码function foo(){ console.log(this.a); } var a = 2; foo();//2我们可以看到调用foo()时,this.a被解析成了全局变量a,为什么,因为在上述例子中,函数调用了默认绑定,因此this指向了全局对象。 那么我们怎么知道这里应用了默认绑