一:this是什么
this是在函数中的概念,在函数内部存在两个特殊的对象,arguments和 this
argument包含着传入函数的所有参数,是以数组的形式返回的
this值指代的是函数值据以执行的环境对象
二:关于this值的指代项
重要的一点:this指向调用函数的那个对象
1,在全局环境下,this指向window
代码如下
window.onload=funtion (){
var name="张宁宁";
function viewthis(){
console.info(this)
}
viewthis();
}
上面是一个非常简单的函数,通过chrome控制台我们可以看到,输出的值为window
因为函数 viewthis为于全局作用域当中,相当于在全局作用域中调用函数,此时this为window
2,当this位于某个对象的方法中的时候,此时的this指代的是那个对象:
代码如下:
window.onload=function (){
var name="the window";
var object={
name:"My object",
getName:function(){
return this.name;
}
}
object.getName();//My object“”
}
上面的代码中,我们调用了函数的方法,方法中的this则指代调用该方法的对象
3,当this位于匿名函数中的时候,对于匿名函数,this的执行环境具有全局性
this对象指向window
代码如下:
var name="the window";
var object={
name="my object",
getNameFunc:function(){
return function(){
return this.name;
}
}
}
alert(object.getNameFunc()());//“the window”
在上面的代码中,匿名函数中的this值指向的执行环境是全局“name”的值
4,通过apply()或者call()可以改变this的值