第一范文网 - 专业文章范例文档资料分享平台

JavaScript之this指针深入详解

来源:用户分享 时间:2025/8/22 16:51:54 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

JavaScript之this指针深入详解

javascript中的this含义非常丰富,它可以是全局对象,当前对象或者是任意对象,这都取决于函数的调用方式。函数有以下几种调用方式:作为对象方法调用、作为函数调用、作为构造函数调用、apply或call调用。

对象方法调用

作为对象方法调用的时候,this会被绑定到该对象。 1. var point = { 2. x : 0, 3. y : 0,

4. moveTo : function(x, y) { 5. this.x = this.x + x; 6. this.y = this.y + y; 7. } 8. };

point.moveTo(1, 1)//this 绑定到当前对象,即 point 对象

这里我想强调一点内容,就是this是在函数执行的时候去获取对应的值,而不是函数定义时。即使是对象方法调用,如果该方法的函数属性以函数名的形式传入别的作用域,也会改变this的指向。我举一个例子: 1. var a = { 2. aa : 0, 3. bb : 0,

4. fun : function(x,y){

5. this.aa = this.aa + x; 6. this.bb = this.bb + y; 7. }

8. };

9. var aa = 1; 10. var b = { 11. aa:0, 12. bb:0,

13. fun : function(){return this.aa;} 14. }

15. a.fun(3,2);

16. document.write(a.aa);//3,this指向对象本身 17. document.write(b.fun());//0,this指向对象本身

18. (function(aa){//注意传入的是函数,而不是函数执行的结果 19. var c = aa();

20. document.write(c);//1 , 由于fun在该处执行,导致this不再指向对象本身,而是这里的window 21. })(b.fun);

这样就明白了吧。这是一个容易混淆的地方。 函数调用

函数也可以直接被调用,这个时候this被绑定到了全局对象。 1. var x = 1;

2. function test(){ 3. this.x = 0; 4. }

5. test();

6. alert(x); //0

但这样就会出现一些问题,就是在函数内部定义的函数,其this也会指向全局,而和我们希望的恰恰相反。代码如下: 1. var point = { 2. x : 0, 3. y : 0,

4. moveTo : function(x, y) { 5. // 内部函数

6. var moveX = function(x) {

7. this.x = x;//this 绑定到了全局 8. }; 9. // 内部函数

10. var moveY = function(y) { 11. this.y = y;//this 绑定到了全局 12. }; 13.

14. moveX(x); 15. moveY(y); 16. } 17. };

18. point.moveTo(1, 1); 19. point.x; //==>0 20. point.y; //==>0 21. x; //==>1 22. y; //==>1

我们会发现不但我们希望的移动呢效果没有完成,反而会多出两个全局变量。那么如何解决呢?只要要进入函数中的函数时将this保存到一个变量中,再运用该变量即可。代码如下:

1. var point = { 2. x : 0, 3. y : 0,

4. moveTo : function(x, y) { 5. var that = this; 6. // 内部函数

7. var moveX = function(x) { 8. that.x = x; 9. };

10. // 内部函数

11. var moveY = function(y) { 12. that.y = y; 13. }

14. moveX(x); 15. moveY(y); 16. } 17. };

18. point.moveTo(1, 1);

19. point.x; //==>1 20. point.y; //==>1 构造函数调用

在javascript中自己创建构造函数时可以利用this来指向新创建的对象上。这样就可以避免函数中的this指向全局了。 1. var x = 2;

2. function test(){ 3. this.x = 1; 4. }

5. var o = new test(); 6. alert(x); //2 apply或call调用

这两个方法可以切换函数执行的上下文环境,也就是改变this绑定的对象。apply和call比较类似,区别在于传入参数时一个要求是数组,一个要求是分开传入。所以我们以apply为例:

1.

var name = \;  2. var someone = {  3.     name: \,  

4. showName: function(){ 5. alert(this.name); 6. } 7. }; 8.

9. var other = {

10. name: \ 11. }; 12.

13. someone.showName(); //Bob

14. someone.showName.apply(); //window 15. someone.showName.apply(other); //Tom

可以看到,正常访问对象中方法时,this指向对象。使用了apply后,apply无参数时,this的当前对象是全局,apply有参数时,this的当前对象就是该参数。 箭头函数调用

这里需要补充一点内容,就是在下一代javascript标准ES6中的箭头函数的 this始终指向函数定义时的 this,而非执行时。我们通过一个例子来理解:

搜索更多关于: JavaScript之this指针深入详解 的文档
JavaScript之this指针深入详解.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c0oyyx0zuat2xn8v9vo2c_1.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top