javascript中的this指向
来源:互联网 发布:数据挖掘视频教程网盘 编辑:程序博客网 时间:2024/06/05 00:35
转载自http://www.cnblogs.com/isaboy/p/javascript_this.html
JavaScript由于其在运行期进行绑定的特性,JavaScript 中的 this 可以是全局对象、当前对象或者任意对象,这完全取决于函数的调用方式。JavaScript 中函数的调用有以下几种方式:作为对象方法调用,作为函数调用,作为构造函数调用,和使用 apply 或 call 调用。
var point = { x : 0, y : 0, moveTo : function(x, y) { this.x = this.x + x; this.y = this.y + y; } };//决策树解释:point.moveTo(1,1)函数不是new进行调用,进入否决策,//是用dot(.)进行调用,则指向.moveTo之前的调用对象,即pointpoint.moveTo(1,1); //this 绑定到当前对象,即point对象
point.moveTo()函数在 “JavaScript this决策树“中进行判定的过程是这样的:
1)point.moveTo函数调用是用new进行调用的么?这个明显不是,进入“否”分支,即函数是否用dot(.)进行调用?;
2)point.moveTo函数是用dot(.)进行调用的,即进入“是”分支,即这里的this指向point.moveTo中.之前的对象point;
function func(x) { this.x = x; } func(5);//this是全局对象window,x为全局变量//决策树解析:func()函数是用new进行调用的么?为否,进入func()函数是用dot进行调用的么?为否,则 this指向全局对象windowx;//x => 5
func()函数在 “JavaScript this决策树“中进行判定的过程是这样的:
1)func(5)函数调用是用new进行调用的么?这个明显不是,进入“否”分支,即函数是否用dot(.)进行调用?;
2)func(5)函数不是用dot(.)进行调用的,即进入“否”分支,即这里的this指向全局变量window,那么this.x实际上就是window.x;
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;
function Point(x,y){ this.x = x; // this ? this.y = y; // this ? }var np=new Point(1,1);np.x;//1var p=Point(2,2);p.x;//error, p是一个空对象undefinedwindow.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.
最后看一下函数用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
p1.moveTo.apply(p2,[10,10])函数在 “JavaScript this决策树“中进行判定的过程是这样的:
我们知道,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;
- javascript中的this指向
- javascript中的this指针到底指向谁~~
- 准确理解javascript中的this的指向
- JavaScript-this的指向
- javascript this指向【图解】
- javascript this指向详解
- JavaScript中this指向
- javascript this关键字指向
- javascript的this指向
- javascript this的指向
- JavaScript This指向
- JavaScript中的call(),apply(),bind()方法 关于this指向
- 四个小demo来了解Javascript中的this指向
- Javascript箭头函数中的this指向错乱的解决办法
- js中的this指向
- JS中的this指向
- JS中的this指向
- 图解javascript this指向什么?
- 求数组相邻元素差值的最大值快速算法(C++版)
- 面试之C题目汇总2
- Ubuntu 下载 & 编译 Android5.1 源码
- sql*plus 常用命令(登陆、连接、执行等)
- 面试之C题目汇总5
- javascript中的this指向
- IE兼容CSS3圆角
- 变量为什么要进行初始化?
- 树链剖分笔记
- Mysql初始化root密码和允许远程访问
- linux系统启动过程分析
- iPhone项目的BaseSDK和DeploymentTarget
- Qt QPainter绘图原理
- Hibernate&Spring学习笔记(杂乱)