妙用缓存调用链实现JS方法的重载


Posted in Javascript onApril 30, 2018

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链式调用,直到找到和当前参数等长的方法~然后进行调用。

funcold 很有可能让初来乍到的童鞋们迷惑,其实不然,这里巧妙的使用了JavaScript语言的特性,这个old每一次保存的都是上一次方法的引用,而且每次都是全新的,而旧的old又保持着引用,这是什么呢?闭包喽~。

Javascript 相关文章推荐
基于jquery的滚动鼠标放大缩小图片效果
Oct 27 Javascript
jquery 添加节点的几种方法介绍
Sep 04 Javascript
自定义jquery模态窗口插件无法在顶层窗口显示问题
May 29 Javascript
node.js中的fs.symlink方法使用说明
Dec 15 Javascript
jquery实现将获取的颜色值转换为十六进制形式的方法
Dec 20 Javascript
JavaScript面向对象的实现方法小结
Apr 14 Javascript
JS+CSS简单树形菜单实现方法
Sep 12 Javascript
three.js快速入门【推荐】
Jan 21 Javascript
BackBone及其实例探究_动力节点Java学院整理
Jul 14 Javascript
jQuery+HTML5实现WebGL高性能烟花绽放动画效果【附demo源码下载】
Aug 18 jQuery
Vue项目使用localStorage+Vuex保存用户登录信息
May 27 Javascript
django中使用vue.js的要点总结
Jul 07 Javascript
JS实现的缓冲运动效果示例
Apr 30 #Javascript
Vue波纹按钮组件制作
Apr 30 #Javascript
学习JS中的DOM节点以及操作
Apr 30 #Javascript
WebSocket的通信过程与实现方法详解
Apr 29 #Javascript
jQuery实现遍历XML节点和属性的方法示例
Apr 29 #jQuery
在vscode里使用.vue代码模板的方法
Apr 28 #Javascript
JS实现的透明度渐变动画效果示例
Apr 28 #Javascript
You might like
PHP 命名空间实例说明
2011/01/27 PHP
CI框架入门之MVC简单示例
2016/11/21 PHP
PHP获取中国时间(上海时区时间)及美国时间的方法
2017/02/23 PHP
php 自定义函数实现将数据 以excel 表格形式导出示例
2019/11/13 PHP
javascript 特殊字符串
2009/02/25 Javascript
JavaScript EasyPager 分页函数
2011/05/25 Javascript
jquery form表单序列化为对象的示例代码
2014/03/05 Javascript
JavaScript实现的购物车效果可以运用在好多地方
2014/05/09 Javascript
Javascript OOP之面向对象
2016/07/31 Javascript
Bootstrap的fileinput插件实现多文件上传的方法
2016/09/05 Javascript
javascript实现去除HTML标签的方法
2016/12/26 Javascript
Javascript下拉刷新的简单实现
2017/02/14 Javascript
vue父子组件的数据传递示例
2017/03/07 Javascript
JavaScript实现简单的星星评分效果
2017/05/18 Javascript
用Axios Element实现全局的请求loading的方法
2018/03/15 Javascript
对Angular中单向数据流的深入理解
2018/03/31 Javascript
React中嵌套组件与被嵌套组件的通信过程
2018/07/11 Javascript
vue实现点击选中,其他的不选中方法
2018/09/05 Javascript
Vue面试题及Vue知识点整理
2018/10/07 Javascript
详解React服务端渲染从入门到精通
2019/03/28 Javascript
vue-property-decorator用法详解
2019/12/12 Javascript
JS原型prototype和__proto__用法实例分析
2020/03/14 Javascript
javascript实现获取中文汉字拼音首字母
2020/05/19 Javascript
python连接MySQL数据库实例分析
2015/05/12 Python
ubuntu系统下 python链接mysql数据库的方法
2017/01/09 Python
Python实现京东秒杀功能代码
2019/05/16 Python
对django views中 request, response的常用操作详解
2019/07/17 Python
如何利用python正则表达式匹配版本信息
2020/12/09 Python
北美三大旅游网站之一:Travelocity
2017/08/12 全球购物
Speedo速比涛法国官方网站:泳衣、泳镜、泳帽、泳裤
2019/07/30 全球购物
水利公司纪检监察自我鉴定
2014/02/25 职场文书
大学生个人自荐信样本
2014/03/02 职场文书
节能环保家庭事迹材料
2014/08/27 职场文书
导游欢迎词范文
2015/01/23 职场文书
运动会宣传语
2015/07/13 职场文书
采购部2015年度工作总结
2015/07/24 职场文书