js中this用法实例详解
更新时间:2015年05月05日 11:33:09 作者:yuan001
这篇文章主要介绍了js中this用法,实例分析了this指向windows、指向对象及改变this指向的相关技巧,需要的朋友可以参考下
本文实例讲述了js中this用法。分享给大家供大家参考。具体如下:
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();
希望本文所述对大家的javascript程序设计有所帮助。
相关文章
JavaScript实现的字符串replaceAll函数代码分享
这篇文章主要介绍了JavaScript实现的字符串replaceAll函数代码分享,本文直接给出实现代码,需要的朋友可以参考下2015-04-04underscore之Collections_动力节点Java学院整理
underscore为集合类对象提供了一致的接口。集合类是指Array和Object,暂不支持Map和Set。下面通过本文给大家分享underscore之Collections的相关知识,需要的的朋友参考下吧2017-07-07
最新评论