回调函数、闭包、this

回调函数:
回调函数:把一个函数当做参数传递就是回调函数
使用:1.不能复用的函数可以放到回调函数中
2.可以解决异步调用的顺序问题

闭包:
闭包就是能读取其他函数内部变量的函数,可以理解为定义在一个函数内部的函数
function foo(){
var a=10;
return function bar(){ //这个函数就是闭包
console.log(a);
}
}
foo()();

既可以保存变量,又可以避免与全局变量冲突
var foo=function foo(){
var a=10;
return function(){
a++;
console.log(a);
}
}();
foo(); //11
foo(); //12
foo(); //13

this指向:
function foo(n1,n2,n3){
console.log(this,n1+n2+n3);
}

foo.call(document,1,2,3); 修改foo中的this指向
第一个参数就是this的指向,第二个开始就是foo函数的参数,修改后立即执行

foo.apply(document,[1,2,3]); 跟call只有传参方式不同

foo.bind(document); 只改变this指向,并不执行函数
例如:document.οnclick=function(){
setTimeout(function(){
console.log(this);
}.bind(document),2000);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值