本人是js菜鸟,对于上面代码,红色标记处执行结果不是很懂。求解、或提示。
newObj.load.bind(newObj);执行了load的bind方法,将object做了绑定,不会执行load方法。
window.setInterval(newObj.load.bind(newObj),1000);此句做循环时,为什么能循环执行load方法呢??load.bind只做了一次。
obj.load.bind(obj),执行结果求解释
Function.prototype.bind=function(object){
var _method=this;
return function(){
_method.apply(object,arguments);
}
}
function TestObj(){}
TestObj.prototype.load=function(){alert("obj's load");}
var newObj=new TestObj();
[color=red]newObj.load.bind(newObj);
window.setInterval(newObj.load.bind(newObj),1000);[/color]
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- blogzhoubo 2012-11-09 09:37关注
1.
newObj.load.bind(newObj);
这行代码调用了bind方法,返回了下面这个函数:
function(){
_method.apply(object,arguments);
}但是,并没有对返回值进行保存,所以仅仅是把load函数
function(){alert("obj's load");}
赋给了_method变量,并且把object绑定到_method方法。
只是返回load方法的定义,并不会执行load方法。2.
window.setInterval(newObj.load.bind(newObj),1000);
这样代码具体执行了下面的操作:
(1)执行newObj.load.bind(newObj),和前面的1.一样
(2)(1)执行完返回的结果(也就是load方法)作为setInterval方法的第一个参数传给setInterval方法,还有1000也传给setInterval方法
(3)执行setInterval方法
(4)setInterval方法内部会每隔1秒调用load方法从上面的1.和2.可以看出,1.扔掉了bind的返回值。2.把返回值传给了setInterval方法,使得setInterval方法可以每隔1秒调用到load方法。
其实第一行红色代码是多余的,可以删掉。
把代码修改成下面这样更容易理解:[code="js"]var newObj=new TestObj();
var m = newObj.load.bind(newObj);
window.setInterval(m,1000); [/code]
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 安装svn网络有问题怎么办
- ¥15 Python爬取指定微博话题下的内容,保存为txt
- ¥15 vue2登录调用后端接口如何实现
- ¥65 永磁型步进电机PID算法
- ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
- ¥88 找成都本地经验丰富懂小程序开发的技术大咖
- ¥15 如何处理复杂数据表格的除法运算
- ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
- ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
- ¥15 latex怎么处理论文引理引用参考文献