方法重载是指在一个类中定义多个同名的方法,但要求每一个方法具备不一样的参数的类型或参数的个数。
简而言之就是:方法重载就是方法名称重复,加载参数不一样。javascript
具体看请左转: 方法重载/百度百科
那么js如何实现这个呢???
java
首先javascript是没有重载函数/方法这个概念的,可是js提供了一个arguments这个方法参数,经过这个参数的length属性就能够拿到方法参数的长度,o~对了,我们今天实现的也仅仅是按照参数长度重载
,而不是参数类型~~·length ,
那么及下载呢,一旦有了方法参数长度,因而出现了比常见的switch写法:缓存
var seven={ dosomething:function(){ switch(arguments.length){ case 0: console.log(arguments.length); //dosomething break; case 1: console.log(arguments.length); //dosomething break; case 2: //dosomething console.log(arguments.length); break; } } }
wow~若是10个方法就须要10个分支~并且很很差维护~由于每一个方法体都在case下,或者单独提出来写成一个function~
而后这些都是很差的~不易维护的,逼格不够高的~那么我们应该如何优雅的实现对于不一样参数的同一方法名的处理呢?
这就用到这个 apply
这个方法了.
我们为seven编写一个addMethod
方法闭包
var seven = { addMethod: function (fname, func) { var old = this[fname]; this[fname] = function () { if (arguments.length == func.length) { return func.apply(this,arguments); } if (typeof old == 'function') { return old.apply(this, arguments); } } } };
修改后的seven如上,而后以前写的switch就能够这样搞了:app
seven.addMethod('dosomething', function (x) { console.log(arguments.length); //dosomething }); seven.addMethod('dosomething', function (x,y) { console.log(arguments.length); //dosomething }); seven.addMethod('dosomething', function (x,y,z) { console.log(arguments.length); //dosomething });
我们要增长方法,只须要调用这个addMethod方法就ok了,是否是以为简单明了,更加清晰。
那么这段代码的原理呢,其实也很简单,就是缓存旧方法,而后根据参数长度依次apply链式调用,直到找到和当前参数等长的方法~而后进行调用。
func
和 old
颇有可能让初来乍到的童鞋们迷惑,其实否则,这里巧妙的使用了JavaScript语言的特性,这个old每一次保存的都是上一次方法
的引用,
并且每次都是全新的,而旧的old又保持着引用,这是什么呢?闭包喽~。函数