妙用缓存调用链实现JS方法的重载
2018-04-30 15:27
726 查看
1.什么是方法重载
方法重载是指在一个类中定义多个同名的方法,但要求每个方法具有不同的参数的类型或参数的个数。
简而言之就是:方法重载就是方法名称重复,加载参数不同。
具体看请左转: 方法重载/百度百科
那么js如何实现这个呢???
2. js如何实现?
首先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; } } }
3.优化
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就可以这样搞了:
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又保持着引用,这是什么呢?闭包喽~。
您可能感兴趣的文章:
相关文章推荐
- 妙用缓存调用链实现JS方法的重载
- 妙用缓存调用链实现JS方法的重载
- js实现调用方法(函数)时可动态传入不同参数个数、模拟实现方法(函数)重载
- 利用sender的Parent获取GridView中的当前行 不用AJAX实现前台JS调用后台C#方法(小技巧) AjaxControlToolkit的CalendarExtender的本地化
- DedeCMS V5.3实现js调用站外调用的方法
- asp.net下利用JS实现对后台CS代码的调用方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧)
- 设置IIS实现禁止js文件缓存及其它两种方法
- 不用AJAX实现前台JS调用后台C#方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧)-转
- 使用MVC中的HtmlHelper对象的ActionLink方法,实现一个Javascript:void(0)效果,去调用一个JS方法
- 普通HTML的input调用Ext js DatePicker的实现方法
- asp.net中js调用服务端方法,服务端调用JS,实现无刷新的倒计时
- 用js实现多域名不同文件的调用方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧)
- 不用AJAX实现前台JS调用后台C#方法(小技巧) (转)
- 学习Altas 笔记[js调用重载的方法出错,如何处理]
- 不用AJAX实现前台JS调用后台C#方法(小技巧)
- js文件中调用js的实现方法小结
- 不用AJAX实现前台JS调用后台C#方法(小技巧)