美文网首页前端你不进来看看?
看懂js中this关键字的指向问题

看懂js中this关键字的指向问题

作者: HarryPang | 来源:发表于2017-09-28 11:04 被阅读60次

this总是指向函数的直接调用者(而非间接调用者);如果有new关键字,this指向new出来的那个对象;在事件中,this指向触发这个事件的对象,特殊的是,IE中的attachEvent中的this总是指向全局对象Window;
通俗的讲,因为this只存在于函数中,而函数是需要被调用的,然后this是谁(对象)调用函数就指向谁(对象)。下面我们看看不同情况下的this指向情况。

1)单纯的函数调用

<script>
function test(){ 
    this.x = 1; 
    alert(this.x)//结果为:1
 };
test();//这里window调用了test函数, window.x即this.x
alert(this.x) ;//结果为:1
alert('x' in window);//结果为:true
</script>
``

2)函数作为对象的方法调用

var test = {
a:1,
b:function(){
alert(this.a);
}
};
test.b();//结果为:1 test调用了函数b,this指向test
alert(this.a);//结果为:undefined  window调用了alert函数,this指向 window而window里并没有a这个属性。

注:在非严格模式下,this没有正确指向,则指向window对象,在严格模式下,没有正确指向,为 undefined。默认就是非严格模式。

3)作为构造函数调用

<script>
function test(){
this.a = 1;
};
var test2 = new test();
alert(test2.a);//结果为:1
</script>

这里this指向的是构造的新对象,也就是 test2,所以test2也有了属性a并等于1。

4)apply()、call() 调用

<script>
var a = 0,
test1 = {
a:1,
fun:function(){
alert(this.a);
}
},
test2 = {
a:2
};
test1.fun();//结果为:1
test1.fun.call(test2);//结果为:2
test1.fun.call();//结果为:0
</script>


这里的三次调用,this分别指向test1、test2和window。第一种前面已经提到了,第二种是通过call或者apply方法使fun中原本指向test1的this变成了指向test2(即call、apply方法的第一个参数)。第三种情况属于第一个参数为空(好像为undefined时也会指向window)时,会默认指向window,..call() =》 ..call(window)。

相关文章

  • 看懂js中this关键字的指向问题

    this总是指向函数的直接调用者(而非间接调用者);如果有new关键字,this指向new出来的那个对象;在事件中...

  • 关于js中this指向的那些事

    this是JS中的关键字,this的指向中函数定义时确定不了,只有 函数指向的时候才能确定this到底指向谁,th...

  • JS进阶篇-this指向问题

    JS中this的指向问题不同于其他语言,JS中的this不是指向定义它的位置,而是在哪里调用它就指向哪里。 JS中...

  • js中this指向问题

    this的指向在函数定义的时候是无法确定的,只有函数执行的时候才能确定this到底指向谁,实际this指向是调用他...

  • JS中this指向问题

    首先声明,添加删除线的都是不太确定的 下面我们分情况解释: 1、函数调用模式--当一个函数并非一个对象的属性时,那...

  • js中this指向问题?

    This是一个关键字,它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用。 this 是在函数被调用时确...

  • js中this的指向问题

    this是Javascript语言的一个关键字它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用,下面分...

  • js 中 this 的指向问题

  • JS中的this指向问题

    1. this的几种绑定方法 (1)普通函数中的this指向函数的调用点 (2) call明确绑定 (3)bind...

  • JS 中的 this指向问题

    程序员就是没有人情味的原始人,不懂交际。谈不到对象。每天就是查看a-z,0-9加上!@#¥%…/&()+-=/<>...

网友评论

    本文标题:看懂js中this关键字的指向问题

    本文链接:https://www.haomeiwen.com/subject/cvemextx.html