全部评论
在这里,bind方法对apply执行的方法再封装。
bind表示看不懂,倒是用过apply。不好意思,我不是做前端的
1.使用apply的原因 由于 new Date()的时候,传入的参数不能是一个数组,因此同上面几个例子一样,主要目的就是通过apply方法变通一下,使得传入的参数由数组解构为变量(可以看下apply的底层实现,如果记得没错的话是在eval执行的过程中会把数组拼接分解为字符串变量)。2.执行bind是对apply的结果进行绑定,形成一个闭包。最后在new的过程中,生成一个Date对象。总结:看似复杂,其实也就是在对一个数组参数在面对一个方法对数组参数不友好时进行合法化。因此es6代码就直接拓展运算符进行解构,使得参数ojbk。个人理解,如有不对,还请各位大腿告之一下
补充: apply call bind区别1.call和apply的区别是,都会改变this指向并且立即执行。call和apply的第一个参数为this所指向的对象,call可以有第二个第三个第四个等等参数,apply第二个参数为一个数组。2.bind也是改变this指向,但是不立即执行,会返回一个闭包函数。apply底层模拟实现:Function.prototype.apply = function (context, arr) { var context = Object(context) || window; context.fn = this; var result; if (!arr) { result = context.fn(); } else { var args = []; for (var i = 0, len = arr.length; i < len; i++) { args.push('arr[' + i + ']'); } result = eval('context.fn(' + args + ')') } delete context.fn return result;}
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享