首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何实现JS函数的重载

本人主要学的是java,也习惯使用面向对象的思维来思考东西,但是我却发现,javascript不能支持函数的重载,如下: function...所以在上面这段代码中,第二个函数是永远不可能被调用到的,那么,要怎样才能实现像函数重载那样的功能呢?     那就是在函数定义中用f.arguments.length判断一下调用时传入的参数个数。...length+",宽为:"+width); }     这样,你就可以给函数f()传入一个参数也可以传入两个参数了,比如f(10)和f(10,10);     个人觉得,这样虽然可以实现重载...,但也不是很好用,我们可以根据具体情况在一个函数中实现重载,如果要重载的两个函数相差较大,那就保留两个函数,而如果两个函数的实现基本差不多,那么可以在一个函数中进行判断,处理不同的部分,而不需要像上面那样写成三个函数

1.5K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript实现函数重载

    我们知道,JavaScript函数可以随意传递任意数量、任意类型的参数,那么它有没有重载呢? 答案是有的,下面我们通过3种方法来实现JavaScript的函数重载实现 0....利用arguments和switch实现重载 people.find = function () { switch (arguments.length) { case 0: return...利用arguments和闭包实现重载 function addMethod (object, name, fn) { // 把前一次添加的方法存在一个临时变量old中 var old = object...因此,每次调用addMethod,都会有一个执行环境保存着当时的old和fn,所以在调用people.find()的时候可以找到当时注入的fn,实现函数重载。 3....总结 JavaScript可以实现函数重载,主要有两种思想: 利用arguments类数组来判断接收参数的个数 利用闭包保存以前注册进来的同名函数

    92040

    【前端自动化】如何使用Node.js实现重载页面

    前言 前不久我结合browser-sync+gulp+gulp-nodemon实现了一款生产环境热更新(我之前理解有点偏差,应该定义为热更新,不是热重载)的项目脚手架,那么,今天我们将使用Node.js...实现一个热重载页面。...热重载 所谓热重载就是页面每次改动,不需要手动去刷新,可自动刷新。 热更新 浏览器的无刷新更新,允许在运行时替换,添加,删除各种模块,而无需进行完全刷新重新加载整个页面。...二、创建Node主文件app.js 下面,我们将创建一个Nodejs操作主文件app.js。...document.querySelector('.name').innerHTML = obj.name; 文件内容如上,我们首先需要关注的是怎么与后台监听

    2.5K10

    Python 函数如何实现重载

    他山之石 首先让我们先来看看其他语言会怎样处理这样的问题: Java 支持方法重载,我们可以编写同名方法,但是这些方法的参数要不一样,主要体现在参数个数与参数类型方面。...下面我们重载了 fprint() 这个静态方法,调用 fprint() 方法时,如果传进来的参数是字符串,那么就调用第一个方法;如果传进来的参数是整型,那么就调用第二个方法。...我是一个整型 666 Python 的解决方案 Python 通过单分派泛函数部分实现了方法重载。...singledispatch 可以实现分派机制就行。...str)part2 -> (str)关注转发 (str)part3 -> (int)666 讲完上面的例子,我们再补充一个小用法: 假如我们想知道 pprint() 函数支持哪些类型,我们该怎么做呢

    82020

    【C++】运算符重载 ③ ( 二元运算符重载 | 运算符重载步骤 | 全局函数 实现 运算符重载 | 成员函数 实现 运算符重载 | 友元函数 实现 运算符重载 )

    运算符重载 使用 全局函数 实现 运算符重载 , 重载 + 运算符 ; 全局函数 实现 运算符重载 : 首先 , 写出函数名 , 函数名规则为 " operate " 后面跟上要重载的运算符 , 函数名是..., 编写具体的运算符操作业务逻辑 ; // 使用 全局函数 实现 运算符重载 // 重载 + 运算符 // 实现两个 Student 对象相加 Student operator+(Student&...运算符重载 使用 成员函数 实现 运算符重载 , 重载 - 运算符 ; 成员函数 实现 运算符重载 : 首先 , 写出函数名 , 函数名规则为 " operate " 后面跟上要重载的运算符 , 函数名是..., 编写具体的运算符操作业务逻辑 ; public: // 使用 成员函数 实现 运算符重载 // 重载 - 运算符 // 实现两个 Student 对象相加 Student operator...二、友元函数实现运算符重载 1、友元函数实现运算符重载 如果类中的成员都是私有成员 , 在 运算符重载 中 , 需要访问 私有成员 进行计算 , 在 成员函数 中 , 可以正常访问 私有成员 , 但是

    17840

    你觉得“惰性求值”在 JS 中会怎么实现

    接上一篇《听君一席话,如听一席话,解释解释“惰性求值”~》,有掘友问:“我懂惰性求值的意思了,但是在 JS 中如何实现 thunk 的呢?”...JS 不像 Haskell,其自身从语言设计层面不支持惰性求值,但是可以通过语法去 模拟实现 这一特性; 想一想,我们可以用什么来 JS 语法来模拟这一“延迟计算”的特性?...赋值的时候,我不进行计算,把你包装成一个 暂停等待,等你调用 next() 的时候,我再计算; 代码 这不就是最简单版本的 JS 惰性求值 Thunk 的实现吗?...实际上 Lazy.js 也正是借助 Generator 实现“惰性”的!...以实现 take 方法为例: 在 Haskell 中,take 函数可以从头连续地取得一个列表的几个元素; Prelude> take 3 [1,2,3,4,5] [1,2,3] JS 模拟实现 take

    1.5K20

    为什么 Python 没有函数重载?如何用装饰器实现函数重载

    函数重载指的是有多个同名的函数,但是它们的签名或实现却不同。当调用一个重载函数 fn 时,程序会检验传递给函数的实参/形参,并据此而调用相应的实现。...因此 Python 不支持函数重载。这是在创造语言时做出的设计决策,但这并不妨碍我们实现它,所以,让我们来重载一些函数吧。...在Python中实现函数重载 我们已经知道 Python 是如何管理命名空间的,如果想要实现函数重载,就需要这样做: 维护一个虚拟的命名空间,在其中管理函数定义 根据每次传递的参数,设法调用适当的函数...为了简单起见,我们在实现函数重载时,通过不同的参数数量来区分同名函数。...这个 get 函数决定了会调用函数的哪个实现(如果重载了的话)。

    3.2K10

    怎么理解JS Promise

    但并不是立即返回最终执行结果,而是一个能代表未来出现的结果的promise对象 看完这段话我的内心一阵无语,我就只能怪我自己的理解能力好像没有达到水准一样,并不完全懂这段话在说什么,这让我一度怀疑我这智商是不是不够用了,怎么就没理解这段话说的是什么意思...我们来看看阮一峰大大是怎么总结的: (1)对象的状态不受外界影响,promise对象代表一个异步操作,有三种状态,pending(进行中)、fulfilled(已成功)、rejected(已失败)。...我们来看看MDN怎么说: onFulfilled 当Promise变成接受状态(fulfillment)时,该参数作为回调函数被调用(参考: Function)。...js异步操作是通过js的事件循环机制EventLoop实现的。...对于异步任务来说,当其可以被执行时,会被放到一个 任务队列(task queue) 里等待JS引擎去执行。

    11.7K30

    【C++】运算符重载 ⑦ ( 一元运算符重载 | 后置运算符重载 | 使用 全局函数 实现 后置 ++ 自增运算符重载 | 使用 成员函数 实现 后置 -- 自减运算符重载 )

    全局函数 实现 后置 ++ 自增运算符重载 使用 全局函数 实现 后置 ++ 自增运算符重载 : 首先 , 写出函数名 , 函数名规则为 " operate " 后面跟上要重载的运算符 , 函数名是 operate..., 编写具体的运算符操作业务逻辑 ; // 使用 全局函数 实现 后置 ++ 自增运算符重载 // 重载 后置 ++ 运算符 // 实现 1 个 Student 对象 自增运算 // 先使用 参数中的...后置 – 自减运算符重载 使用 成员函数 实现 后置 – 自减运算符重载 : 首先 , 写出函数名 , 函数名规则为 " operate " 后面跟上要重载的运算符 , 函数名是 operate--..., 编写具体的运算符操作业务逻辑 ; public: // 使用 成员函数 实现 后置 -- 自减运算符重载 // 重载 后置 -- 运算符 // 实现 1 个 Student 对象 自减运算...前置 ++ 自增运算符重载 // 重载 前置 ++ 运算符 // 实现 1 个 Student 对象 自增运算 // 由于 参数中的 Student& s 中的属性发生了变化 // 返回时仍需要返回

    19040

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券