JS编程建议——56:使用arguments模拟重载

简介: 56:使用arguments模拟重载

建议56:使用arguments模拟重载
在JavaScript中,每个函数内部可以使用arguments对象,该对象包含了函数被调用时的实际参数值。arguments对象虽然在功能上与数组有些类似,但它不是数组。 arguments 对象与数组的类似体现在它有一个 length 属性,同时实际参数的值可以通过[]操作符来获取,但arguments对象并没有数组可以使用的push、pop、splice等方法。其原因是arguments对象的prototype指向的是Object.prototype,而不是Array.prototype。
Java和C++语言都支持方法重载,即允许出现名称相同而形式参数不同的方法,但JavaScript并不支持这种方式的重载。这是因为JavaScript中的function对象也是以属性的形式出现的,在一个对象中增加与已有function 同名的新function时,旧的function对象会被覆盖。不过可以通过使用arguments来模拟重载,其实现机制是通过判断arguments中实际参数的个数和类型来执行不同的逻辑。
function sayHello() {

switch (arguments.length) {
    case 0:
        return "Hello";
    case 1:
        return "Hello, " + arguments[0];
    case 2:
        return (arguments[1] == "cn" ? " 你好," : "Hello, ") + arguments[0];
};

}
sayHello(); //"Hello"
sayHello("Alex"); // "Hello, Alex"
sayHello("Alex", "cn"); // " 你好,Alex"
callee是arguments对象的一个属性,其值是当前正在执行的function对象。它的作用是使匿名 function可以被递归调用。下面以一段计算斐波那契序列中第N个数的值的过程来演示arguments.callee的使用。
function fibonacci(num) {

return (function(num) {
    if( typeof num !== "number")
        return -1;
    num = parseInt(num);
    if(num < 1)
        return -1;
    if(num == 1 || num == 2)
        return 1;
    return arguments.callee(num - 1) + arguments.callee(num - 2);
})(num);

}
fibonacci(100);

相关文章
|
3月前
|
JavaScript
Nest.js 实战 (十一):配置热重载 HMR 给服务提提速
这篇文章介绍了Nest.js服务在应用程序引导过程中,TypeScript编译对效率的影响,以及如何通过使用webpackHMR来降低应用实例化的时间。文章包含具体教程,指导读者如何在项目中安装依赖包,并在根目录下新增webpack配置文件webpack-hmr.config.js来调整HMR相关的配置。最后,文章总结了如何通过自定义webpack配置来更好地控制HMR行为。
|
3月前
|
存储 JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果+1
JavaScript编程实现tab选项卡切换的效果+1
|
4月前
|
JavaScript 前端开发 编译器
解锁JavaScript模块化编程新纪元:从CommonJS的基石到ES Modules的飞跃,探索代码组织的艺术与科学
【8月更文挑战第27天】随着Web应用复杂度的提升,JavaScript模块化编程变得至关重要,它能有效降低代码耦合度并提高项目可维护性及扩展性。从CommonJS到ES Modules,模块化标准经历了显著的发展。CommonJS最初专为服务器端设计,通过`require()`同步加载模块。而ES Modules作为官方标准,支持异步加载,更适合浏览器环境,并且能够进行静态分析以优化性能。这两种标准各有特色,但ES Modules凭借其更广泛的跨平台兼容性和现代语法逐渐成为主流。这一演进不仅标志着JavaScript模块化的成熟,也反映了整个JavaScript生态系统的不断完善。
53 3
|
23天前
|
前端开发 JavaScript 持续交付
提高JavaScript编程效率
提高JavaScript编程效率
25 3
|
1月前
|
自然语言处理 JavaScript 前端开发
JavaScript闭包:解锁编程潜能,释放你的创造力
【10月更文挑战第25天】本文深入探讨了JavaScript中的闭包,包括其基本概念、创建方法和实践应用。闭包允许函数访问其定义时的作用域链,常用于数据封装、函数柯里化和模块化编程。文章还提供了闭包的最佳实践,帮助读者更好地理解和使用这一强大特性。
19 2
|
3月前
|
JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果
JavaScript编程实现tab选项卡切换的效果
|
3月前
|
JavaScript 前端开发
用JavaScript编程控制网页上checkbox选择状态:全选、全部取消、反选
用JavaScript编程控制网页上checkbox选择状态:全选、全部取消、反选
|
3月前
|
JavaScript 前端开发 安全
JavaScript编程实现字符和字符串翻转
JavaScript编程实现字符和字符串翻转
|
3月前
|
JavaScript 前端开发
用JavaScript编程定义二维数组并初始化,然后输出元素值
用JavaScript编程定义二维数组并初始化,然后输出元素值
|
4月前
|
存储 JavaScript 对象存储
JS中的arguments是什么?
JS中的arguments是什么?
59 0
JS中的arguments是什么?