this的使用

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)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值