博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深入理解JavaScript中的this关键字
阅读量:5114 次
发布时间:2019-06-13

本文共 2418 字,大约阅读时间需要 8 分钟。

来自于:http://www.cnblogs.com/rainman/archive/2009/05/03/1448392.html

在JavaScript中this变量是一个令人难以摸清的关键字,this可谓是非常强大,充分了解this的相关知识有助于我们在编写面向对象的JavaScript程序时能够游刃有余。

对于this变量最要的是能够理清this所引用的对象到底是哪一个,也许很多资料上都有自己的解释,但有些概念讲的偏繁杂。而我的理解是:首先分析this所在的函数是当做哪个对象的方法调用的,则该对象就是this所引用的对象。
示例一、
var obj = {};
obj.x = 100;
obj.y = function(){ alert( this.x ); };
obj.y();    //弹出 100
这段代码非常容易理解,当执行 obj.y() 时,函数是作为对象obj的方法调用的,因此函数体内的this指向的是obj对象,所以会弹出100。
示例二、
Code
ExpandedBlockStart.gif
代码
var
 checkThis 
=
 
function
(){
    alert( 
this
.x);
};
var
 x 
=
 
'
this is a property of window
'
;
var
 obj 
=
 {};
obj.x 
=
 
100
;
obj.y 
=
 
function
(){ alert( 
this
.x ); };
obj.y();    
//
弹出 100
checkThis();    
//
弹出 'this is a property of window'

这里为什么会弹出 'this is a property of window',可能有些让人迷惑。在JavaScript的变量作用域里有一条规则“全局变量都是window对象的属性”。当执行 checkThis() 时相当于 window.checkThis(),因此,此时checkThis函数体内的this关键字的指向变成了window对象,而又因为window对象又一个x属性( 'this is a property of window'),所以会弹出 'this is a property of window'。
上面的两个示例都是比较容易理解的,因为只要判断出当前函数是作为哪个对象的方法调用(被哪个对象调用)的,就可以很容易的判断出当前this变量的指向。
this.x 与 apply()、call()
通过call和apply可以重新定义函数的执行环境,即this的指向,这对于一些应用当中是十分常用的。
示例三:call()
Code
ExpandedBlockStart.gif
代码
function
 changeStyle( type , value ){
    
this
.style[ type ] 
=
 value;
}
var
 one 
=
 document.getElementById( 
'
one
'
 );
changeStyle.call( one , 
'
fontSize
'
 , 
'
100px
'
 );
changeStyle(
'
fontSize
'
 , 
'
300px
'
);  
//
出现错误,因为此时changeStyle中this引用的是window对象,而window并无style属性。

注意changeStyle.call() 中有三个参数,第一个参数用于指定该函数将被哪个对象所调用。这里指定了one,也就意味着,changeStyle函数将被one调用,因此函数体内 this指向是one对象。而第二个和第三个参数对应的是changeStyle函数里的type和value两个形参。最总我们看到的效果是Dom元素 one的字体变成了20px。
示例四:apply()
Code
ExpandedBlockStart.gif
代码
function
 changeStyle( type , value ){
    
this
.style[ type ] 
=
 value;
}
var
 one 
=
 document.getElementById( 
'
one
'
 );
changeStyle.apply( one , [
'
fontSize
'
 , 
'
100px
'
 ]);
changeStyle(
'
fontSize
'
 , 
'
300px
'
);  
//
出现错误,原因同示例三
apply的用法和call大致相同,只有一点区别,apply只接受两个参数,第一个参数和call相同,第二个参数必须是一个数组,数组中的元素对应的就是函数的形参。
无意义(诡异)的this用处
示例五:
ExpandedBlockStart.gif
代码
Code
var
 obj 
=
 {
    x : 
100
,
    y : 
function
(){
        setTimeout(
            
function
(){ alert(
this
.x); }    
//
这里的this指向的是window对象,并不是我们期待的obj,所以会弹出undefined
         , 
2000
);
    }
};
obj.y();
如何达到预期的效果
var
 obj 
=
 {
    x : 
100
,
    y : 
function
(){
        
var
 that 
=
 
this
;
        setTimeout(
            
function
(){ alert(that.x); }
         , 
2000
);
    }
};
obj.y();    
//
弹出100
事件监听函数中的this
var
 one 
=
 document.getElementById( 
'
one
'
 );
one.onclick 
=
 
function
(){
    alert( 
this
.innerHTML );    
//
this指向的是one元素,这点十分简单..
};

转载于:https://www.cnblogs.com/jikey/archive/2010/05/05/1728257.html

你可能感兴趣的文章
第一个Spring冲刺周期团队进展报告
查看>>
红黑树 c++ 实现
查看>>
Android 获取网络链接类型
查看>>
linux中启动与终止lnmp的脚本
查看>>
gdb中信号的处理[转]
查看>>
LeetCode【709. 转换成小写字母】
查看>>
如何在Access2007中使用日期类型查询数据
查看>>
Jzoj4757 树上摩托
查看>>
CF992E Nastya and King-Shamans(线段树二分+思维)
查看>>
第一个Java Web程序
查看>>
树状数组_一维
查看>>
如果没有按照正常的先装iis后装.net的顺序,可以使用此命令重新注册一下:
查看>>
linux install ftp server
查看>>
嵌入式软件设计第8次实验报告
查看>>
算法和数据结构(三)
查看>>
Ubuntu下的eclipse安装subclipse遇到没有javahl的问题...(2天解决了)
查看>>
alter database databasename set single_user with rollback IMMEDIATE 不成功问题
查看>>
Repeater + Resources 列表 [原创][分享]
查看>>
WCF揭秘——使用AJAX+WCF服务进行页面开发
查看>>
【题解】青蛙的约会
查看>>