首页 > 网站 > WEB开发 > 正文

js中的this指向

2024-04-27 14:09:55
字体:
来源:转载
供稿:网友

js中的this指向

2015-05-05 09:57 by yuan001, ... 阅读, ... 评论, 收藏, 编辑

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 Windowalert(box.getThis());//the boxalert(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();

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表