this关键字的使用
在属性中
var obj={
a:1,
b:function(){
console.log(this.a) //属性中的参数指向调用者obj
}
}
obj.b()
在函数中
var c=2
function fn(){
console.log(this) //指window;
}
fn()
在回调函数中
不管会掉的函数之前this指向什么,一旦被回调统一指向window;
var a=10
function fn(f){
f(); //由于使用回调函数调用obj.b,obj.b原本this指向obj,调用后指向window
}
var obj={
a:1,
b:function(){
console.log(this.a) //属性中的参数指向调用者obj
}
}
fn(obj.b)
使用arguments完成回调函数的执行时
不管回调的函数this指向什么,在这里统一指向当前的arguments
arguments表示参数,此变量存着一个数组的引用,数组里面都是实参
var a=10
function fn(f){
arguments0; //使用arguments执行回调函数,回调的函数this指向arguments
}
var obj={
a:1,
b:function(){
console.log(this) //属性中的参数指向调用者obj
}
}
fn(obj.b,a)
arguments
function main(f){
f(3,5);
}
function fn2(a,b){
console.log(arguments.callee); //指当前执行的函数 指代匿名函数更方便
console.log(arguments.callee.caller);//指当前执行的函数的调用者
console.log(fn2.caller);
}
main(fn2)