参考回答:
原理:通过apply或者call方法来实现。
(1)初始版本
Function.prototype.bind=function(obj,arg){var arg=Array.prototype.slice.call(arguments,1);var context=this;return function(newArg){arg=arg.concat(Array.prototype.slice.call(newArg));return context.apply(obj,arg);}}
(2) 考虑到原型链
为什么要考虑?因为在new 一个bind过生成的新函数的时候,必须的条件是要继承原函数的原型
Function.prototype.bind=function(obj,arg){var arg=Array.prototype.slice.call(arguments,1);var context=this;var bound=function(newArg){arg=arg.concat(Array.prototype.slice.call(newArg));return context.apply(obj,arg);}var F=function(){}
//这里需要一个寄生组合继承
F.prototype=context.prototype;bound.prototype=new F();return bound;}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)