码迷,mamicode.com
首页 > Web开发 > 详细

js中的this指向

时间:2015-05-05 10:22:59      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:

1, 指向window

全局变量 alert(this) //返回 [object Window]

全局函数

  

function sayHello(){
    alert(this);
}

sayHello();

  2, 指向该对象(在全局里面this指向window,在某个对象里面this指向该对象,在闭包里面this指向window)

var user="the Window";
var box={
    user:‘the box‘,
    getThis:function(){
        return this.user;
    },
    getThis2:function(){
        return function (){
            return this.user;
        }
    }
};

alert(this.user);//the Window
alert(box.getThis());//the box
alert(box.getThis2()());//the Window (由于使用了闭包,这里的this指向window)
alert(box.getThis2().call(box));//the box  对象冒充(这里的this指向box对象)

3,用apply,call改变函数的this指向

 function sum(num1, num2){
        return num1+num2;
    }

    function box(num1, num2){
        return sum.apply(this, [num1, num2]); //this 表示window的作用域 box冒充sum来执行
    }

    console.log(box(10,10)); //20
 
 

4, new 对象

function Person(){
        console.log(this) //将 this 指向一个新建的空对象
    }
    var p = new Person();

js中的this指向

标签:

原文地址:http://www.cnblogs.com/yuan001/p/4478361.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!