源码来袭:callapply手写实现与应用
Posted 他乡踏雪
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了源码来袭:callapply手写实现与应用相关的知识,希望对你有一定的参考价值。
关于this指向可以了解我的另一篇博客:JavaScript中的this指向规则。
一、call与apply的使用
- 回顾call与apply的this指向:
var value = "window"; var obj = { value:"obj" } fonction show(){ console.log(this.value); } show();//window show.call(obj);//obj show(null);//window
- 回顾call与apply的参数使用:
var sum1 = 1, sum2 = 2, c = 3, obj = { c:4 } function show(a,b){ console.log( a + b + this.c); } show(sum1,sum2);//6 show.call(obj,sum1,sum2);//7 show.apply(obj,[sum1,sum2]);//7
二、call与apply的手写实现
思路:
show.call(obj); //代码可以被以下三行代码替代 obj.show = show; obj.show(); delete = obj.show;
call手写实现:
1 Function.prototype.MyCall = function(){ 2 var ctx = arguments[0] || window; 3 ctx.fn = this; 4 var args = []; 5 for(var i = 1; i < arguments.length; i++){ 6 args.push(arguments[i]); 7 } 8 var result = eval(\'ctx.fn(\' + args.join(",") + \')\'); 9 delete ctx.fn; 10 return result; 11 }
apply手写实现:
1 Function.prototype.MyApply = function(obj,arr){ 2 var ctx = obj || window; 3 ctx.fn = this; 4 arr = arr || []; 5 eval(\'ctx.fn(\' + arr.join(",") + \')\'); 6 delete ctx.fn; 7 }
以上是关于源码来袭:callapply手写实现与应用的主要内容,如果未能解决你的问题,请参考以下文章