首页 web前端 js教程 JS函数重载的解决方案_javascript技巧

JS函数重载的解决方案_javascript技巧

May 16, 2016 pm 04:48 PM
javascript js 函数重载

在面向对象的编程中,很多语言都支持函数重载,能根据函数传递的不同个数、类型的参数来做不同的操作,JS对它却不支持,需要我们额外做些小动作。
  
  在JS的函数执行上下文中有一个名为arguments的有意思的变量,它以数组的形式存储了函数执行时传递过来的所有参数,即使函数定义没有定义这 么多个形参。还有一个特别之处就是跟Array类型相比,arguments变量有且只有一个length属性,Array的方法,例如push、pop 等,它并不具备,它只是一个“伪数组”:具有length属性,存储的数组能够用数组访问符[]来访问,并且是只读不可写。

一、对于不同个数参数的重载
  这里应该很明白,直接用arguments函数的length属性来判断就可以了。


复制代码 代码如下:


二、对于不同类型的参数的重载 
  对于JS这样一种动态类型的语言,这种变量声明的随意性淡化了严格的变量类型在开发人员脑子里的重要性(PS:同样是基于ECMA体系的,AS就引入 了变量声明的强制类型),很多意想不到的BUG其实都是由这种变量类型的自动转换造成的。其实JS提供了很准确的方法让我们来严格检测变量的类型,比较通 用的就是typeof方法和constructor属性。

1、typeof variable 返回变量类型

复制代码 代码如下:

temp = "say"; //string
temp = 1; //number
temp = undefined; //undefined
temp = null; //object
temp = {}; //object
temp = []; //object
temp = true; //boolean
temp = function (){} //function
alert(typeof temp);

    通过上面的测试你可以看出来,对于null,Object,Array返回的都是object类型,而使用下面的方法就可以解决这个困扰。

2.constructor属性检测变量类型

    JS中每个对象都有constructor属性,它是用来引用构造此对象的函数,通过对这个引用的判断就可以检测变量类型了。

复制代码 代码如下:

temp = "say";
temp.constructor==String; //true
temp= {};
temp.constructor == Object;//true
temp= [];
temp.constructor == Array;//true

    通过上面的测试已经很容易的把Array和Object类型的变量区分开了。下面我们来对自定义的对象做个测试看看会发生什么。

复制代码 代码如下:

//自定义对象
function Ball(){}
//实例化一个对象
var basketBall = new Ball();
basketBall.constructor==Ball; //true

    这可以说明constructor属性对于自定义的对象一样适用。

  在弄清楚了上面两个方法的适用以后再来回到JS函数重载的模拟上来,下面这个例子是根据参数类型来重载。

复制代码 代码如下:

function talk(msg){
     var t = typeof msg;
     if(t=="string"){
            alert("It's a string");
    }
    else if(t=="number"){
            alert("It's a number");
     }
}
talk(10); //It's a string
talk("demo"); //It's a number

附上一个很巧妙的严格检测参数类型和个数的函数:

复制代码 代码如下:

//依据参数列表来严格地检查一个变量列表的类型
function strict( types, args ) {
     //确保参数的数目和类型核匹配
     if ( types.length != args.length ) {
            //如果长度不匹配,则抛出异常
           throw "Invalid number of arguments. Expected " + types.length + ", received " + args.length + " instead.";
    }
    //遍历每一个参数,检查基类型
    for ( var i = 0; i           //如JavaScript某一项类型不匹配,则抛出异常
          if ( args[i].constructor != types[i] ) {
                throw "Invalid argument type. Expected " + types[i].name +", received " + args[i].constructor.name + " instead.";
          }
     }
}

//上述方法的使用
function doFunction(id,name){
     //检测参数个数和类型
     strict([Number,String],arguments);
  ..
}

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

推荐:优秀JS开源人脸检测识别项目 推荐:优秀JS开源人脸检测识别项目 Apr 03, 2024 am 11:55 AM

人脸检测识别技术已经是一个比较成熟且应用广泛的技术。而目前最为广泛的互联网应用语言非JS莫属,在Web前端实现人脸检测识别相比后端的人脸识别有优势也有弱势。优势包括减少网络交互、实时识别,大大缩短了用户等待时间,提高了用户体验;弱势是:受到模型大小限制,其中准确率也有限。如何在web端使用js实现人脸检测呢?为了实现Web端人脸识别,需要熟悉相关的编程语言和技术,如JavaScript、HTML、CSS、WebRTC等。同时还需要掌握相关的计算机视觉和人工智能技术。值得注意的是,由于Web端的计

如何区分 C++ 中函数重载和重写 如何区分 C++ 中函数重载和重写 Apr 19, 2024 pm 04:21 PM

函数重载允许一个类中具有同名但签名不同的函数,而函数重写发生在派生类中,当它覆盖基类中具有相同签名的函数,提供不同的行为。

PHP 函数的重载和重写 PHP 函数的重载和重写 Apr 26, 2024 pm 05:12 PM

PHP中支持函数重载和重写,可创建灵活可重用的代码。函数重载:允许创建同名函数,但参数不同,根据参数匹配情况调用最合适的函数。函数重写:允许子类定义同名函数,覆盖父类方法,子类方法调用时将覆盖父类方法。

golang如何实现函数重载? golang如何实现函数重载? Apr 29, 2024 pm 05:21 PM

Go语言不支持传统函数重载,但可以通过以下方法实现类似效果:使用命名函数:为不同参数或返回类型的函数创建唯一名称;使用泛型(Go1.18及以上):为不同类型参数创建函数的单个版本。

js和vue的关系 js和vue的关系 Mar 11, 2024 pm 05:21 PM

js和vue的关系:1、JS作为Web开发基石;2、Vue.js作为前端框架的崛起;3、JS与Vue的互补关系;4、JS与Vue的实践应用。

C++ 函数重载的最佳实践 C++ 函数重载的最佳实践 Apr 20, 2024 am 10:48 AM

C++函数重载最佳实践:1、使用清晰且有意义的名称;2、避免过载过多;3、考虑默认参数;4、保持参数顺序一致;5、使用SFINAE。

C++ 函数重载是否适用于构造函数和析构函数? C++ 函数重载是否适用于构造函数和析构函数? Apr 14, 2024 am 09:03 AM

C++构造函数支持重载,而析构函数不支持。构造函数可具有不同的参数列表,而析构函数只能有一个空参数列表,因为它在销毁类实例时自动调用,不需输入参数。

C++ 函数重载在实际项目中的应用场景? C++ 函数重载在实际项目中的应用场景? Apr 26, 2024 pm 01:57 PM

函数重载允许在C++中以不同方式定义具有相同名称的函数,处理不同类型的参数或执行不同操作。具体应用场景包括:处理不同数据类型提供不同的功能提高代码可读性

See all articles