js 函数的重载

我们知道,很多编程语言都有函数的重载。

所谓的重载,看定义:

重载,简单说,就是函数或者方法有相同的名称,但是参数列表不相同的情形,这样的同名不同参数的函数或者方法之间,互相称之为重载函数或者方法。

同名函数,根据传入的参数类型不同,来执行对应的方法。

所以从这个定义中,我们能够得出,js 并不具备函数的重载功能。

因为 js 不用对传入的参数的类型,进行严格的定义。所以,即使我们写了同名的函数,也只会导致后面的函数会将前面的函数覆盖掉。

现在我们假设,即使 js 同名函数能够共存,但是我们无法知道不同的同名函数分别接收什么类型的参数,同样无法判断该调用哪一个方法。

但是我们在平时写代码的过程中,有一种情况是比较常见的。

比如,我们现在有一个对象 People,有私有属性 name 和 age。

因为 JavaScript 中没有私有属性,所以我们只能通过闭包来模拟私有属性。

所以,我们在构造函数内部定义 name 和 age 对象,通过 get,set 接口来统一读取和修改他们。

代码见下面所示。

var 

用的时候,我们可以这样:

// 防止构造函数中没用 new 我们检测了一下 this 的指向

可以看到,这里,我们通过用了 get 和 set 函数,来对外提供接口。

那么,我们想一想,我们能不能将这两个函数合并一下,通过同一个函数,来实现这两种功能呢?

答案当然是肯定的,我么可以改写一下我们之前的构造函数:

var 

再看下我们的使用过程:

var 

可以看出来,这样一改,这个接口调用起来就很方便了。

虽然乍一看,这样该写了以后,好像不太好理解。但是如果习惯了这种写法以后,你会感受到这种写法的奇妙之处。简直太方便了,传一个参数就是拿值,传两个参数,就是改写对应的值。

当然这种写法,是我们在架构我们的项目的时候,有这种意识,这当然算是一种比较好的写法了。

但是如果我们刚开始架构的时候,是这样写的:

var 

随着我们项目的进行,可能在原型链上,有很多方法都用到了 this._name 或者 this._age。

这个时候,如果想要迁移我们的变量成闭包内部的变量,当然是不划算的,改写起来太麻烦了。

但是如果我们又想要提供一个类似于之前的 o 函数,该怎么做呢?

也许又童鞋得第一反应是,这还不简单,三下五除二的进行了如下的拓展:

People

这样写固然没有问题,但是还是不太具备扩展性。

如果,某一天,我们突发奇想,想要拓展一下这个 o 方法,当不传参数的时候,我们想要列出实例上所有的属性。

我们固然可以通过重载这个 o 方法来实现,但是总感觉不够优雅。

现在有一种更为优雅的方式。

我们可以创建一个 overload 方法用于重载:

function 

我们可以这样调用:

overload

我们还可以继续扩展:

overload

可以看出来,我们的重载函数,非常的强大,扩展性也是非常的强。

可以对任意一个对象上的函数进行重载,当然这里是通过识别参数的个数来进行重载的,这也是现阶段 js 中所能做到的极限了。

这个小小的 overload 方法,同样也是通过闭包来实现的重载。

原理就是通过比较函数的参数与传入的参数个数是否相等,相等则用调用当前函数进行执行。如果不相等,那么调用 old 函数,进行执行。而 old 函数同样会递归执行参数个数判断这一过程,这样就实现了根据参数的个数对函数进行重载。

js根据name获取value_js 函数的重载相关推荐

  1. Javascript(二)——函数(重载、回调)与作用域(附图解)

    文章目录 一.函数 1.1函数的本质 1.2创建函数 1) 声明方式 function 2) 赋值方式 3)new创建--几乎不用 4)ES5-create()方法 1.2 递归 1.3 重载函数 1 ...

  2. matlab私有函数,MATLAB 嵌套函数,子函数,私有函数,重载函数

    MATLAB函数嵌套 MATLAB中M文件有两种类型,脚本M文件和函数M文件.脚本M文件是将可执行程序语句放入M文件中,就像在命令窗口那样,按其语句顺序及逻辑关系执行,可以理解为一般的顺序执行程序语句 ...

  3. 原生js已载入就执行函数_手写CommonJS 中的 require函数

    前言 来自于圣松大佬的文章<手写CommonJS 中的 require函数> 什么是 CommonJS ? node.js 的应用采用的commonjs模块规范. 每一个文件就是一个模块, ...

  4. 获取成员函数地址及获取函数地址

     首先我们定义一个类Ctest,类里面包含三个不同形式的成员函数,静态成员函数statFunc().动态成员函数dynFunc()和虚拟函数virtFunc().在main函数中我们利用cout标 ...

  5. java_函数的重载

    函数的重载(Overload) 概念:在同一个类中,允许存在一个以上的同名函数,只要他们的参数个数或者参数类型不同即可. 函数功能一样,仅仅是参与运算的未知内同不同时,可以定义多函数,却使用统一函数名 ...

  6. js有默认参数的函数加参数_函数参数:默认,关键字和任意

    js有默认参数的函数加参数 PYTHON开发人员的提示 (TIPS FOR PYTHON DEVELOPERS) Think that you are writing a function that ...

  7. main.js中封装全局登录函数

    main.js中封装全局登录函数 1. 在 main.js 中封装全局登录函数 通过 vue 对象的原型扩展,可以扩展一个函数,这样这个函数就可以在 每一个界面通过类似指向对象的方式,去访问这个函数. ...

  8. 【cocos2d-x从c++到js】14:注册函数

    前面的文章中讲过,在游戏启动时,会调用大量的addRegisterCallback函数,向SpiderMonkey注册Cocos2d-x引擎的函数. 1 2 3 4 5 6 7 8 9 10 11 1 ...

  9. 破解网易云js加密,爬虫获取网易云评论

    破解网易云js加密,爬虫获取网易云评论 抓包 这里是对网页版的网易云音乐进行抓包,分析网络请求,url https://music.163.com/#/song?id=36229055 然后可以发现 ...

最新文章

  1. 字节数与字符数mysql_数据库字段长短之字节与字符
  2. Shell命令-系统信息及显示之uname、hostname
  3. 信息学奥赛C++语言:for_求和
  4. odbc驱动程序管理器连接未打开_Windows 10 怎么修复 Windows 中的 Wi-Fi 连接问题,我教你...
  5. vue template 复用_vue-组件基础
  6. ”易书网“开发总结——管理篇
  7. 诸如fluke等网络测试仪的工作原理简介
  8. 齿轮传动设计分析软件 KISSsoft 03-2018 中英文版 带安装视频
  9. OpenWrt设置开机自动启动/延迟启动
  10. 欧洲赢麻了!互联网巨头被迫拆围墙;git常用命令速查;Diffusion扩散模型实例教程集;高效C++机器学习库;前沿论文 | ShowMeAI资讯日报
  11. Hexo-next主题优化篇
  12. logparser使用_分析您的Web服务器数据并使用LogParser和Log Parser Lizard GUI进行授权
  13. 找出数组中最大元素的位置(下标值)
  14. 分布式动态路由的实现
  15. 利用python构建马科维茨_R语言动量和马科维茨Markowitz投资组合(Portfolio)模型实现...
  16. libreoffice python_如何在LibreOffice中运行python宏?
  17. 副号显示无服务器,小升初||网报遇BUG,最全解决方案都在这里了
  18. RF Python扩展测试库
  19. 微信公众号开发C#系列-12、微信前端开发利器:WeUI
  20. 【第3篇】人工智能(AI)语音测试原理和实践

热门文章

  1. Oracle数据库 invalid character问题解决
  2. 不妨问问自己,学习C语言是为了什么?
  3. mysql查找大小写_mysql查询不区分大小写
  4. VS Code的Error: Running the contributed command: ‘_workbench.downloadResource‘ failed解决
  5. java jps都卡死,java长时间运行后,jps失效
  6. erp 维护费 要交吗_ERP系统维护费
  7. 系统新模块增加需要哪些步骤_想要吸引人流,儿童乐园需要增加哪些新设备呢...
  8. html 图片墙效果,基于html5实现的图片墙效果
  9. 华尔街顶级大师胡立阳名言
  10. Knapsack Cryptosystem【折半+查找】