javascript function调用时的参数检测常用办法
作者:bea
代码如下: var f1 = function(p1,p2,p3){ switch(arguments.length){ case 0: alert("无参版本的f1") break; case 1: alert("1个参数版本的f1:" + p1) break; case 2: alert("2个参数版本的f1:" + p1 + "," + p2) break; case 3: alert("3个参数版本的f1:" + p1 + "," + p
代码如下:
var f1 = function(p1,p2,p3){
switch(arguments.length){
case 0:
alert("无参版本的f1")
break;
case 1:
alert("1个参数版本的f1:" + p1)
break;
case 2:
alert("2个参数版本的f1:" + p1 + "," + p2)
break;
case 3:
alert("3个参数版本的f1:" + p1 + "," + p2 + "," + p3)
break;
default:
alert("不支持多于3个参数的调用!");
break;
}
}
f1();
f1("1");
f1("a",100);
f1("1","2","3");
f1("1","2","3","4")
2.参数个数检测
js引擎同样也不会在function调用时,强制检查参数个数,所以只能自己处理,示例代码:
代码如下:
var fnMustOneParam = function(p){
//检测有没有参数传入
if (typeof p=="undefined"){
alert("fnMustOneParam必须要有参数传入,才能调用(1)!");
return ;
}
//也可以写成这样
if (arguments.length==0){
alert("fnMustOneParam必须要有参数传入,才能调用(2)!");
return;
}
//检测参数个数
if (arguments.length!=0){
alert("fnMustOneParam只能传入一个参数调用!");
return;
}
//to do...
}
//fnMustOneParam(1,3,4);
3.参数基本类型检测
js引擎同样更不会检测参数的类型,如果您希望对参数的基本类型做些限制,可以利用typeof 来判断基本类型
代码如下:
var fnString = function(s){
if (arguments.length!=1){
alert("参数个数不匹配!");
return ;
}
if (typeof s != "string"){
alert("只能传入string类型的参数!");
return ;
}
}
//fnString(123);
4.自定义类的参数类型检测
第3条所提到的方法,只能检测参数的基本类型,如果是自定义类的参数,如果用typeof运算符号,只能得到object的类型检测结果,这时可利用instanceof运算符号来解决
代码如下:
function Person(name,age){
this.name = name;
this.age = age;
}
function fnPerson(p){
if (arguments.length=1 && p instanceof Person){
alert("fnPerson调用成功,p.name=" + p.name + ",p.age=" + p.age);
}
else{
alert("必须传入一个Person类型的参数才能调用!");
}
}
fnPerson("asdf");
fnPerson(new Person('菩提树下的杨过',30))
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 几个比较经典常用的jQuery小技巧
- 基于JQuery的密码强度验证代码
- Jquery下的26个实用小技巧(jQuery tips, tricks & solutions)
- 基于jquery.Jcrop的头像编辑器
- IE event.srcElement和FF event.target 功能比较
- Javascript 判断客户端浏览器类型代码
- 在chrome中window.onload事件的一些问题
- 仅用[]()+!等符号就足以实现几乎任意Javascript代码
- Javascript 网页水印(非图片水印)实现代码
- 使用js获取QueryString的方法小结
- js实现的八点拖动修改div大小的代码
- JavaScript 面向对象代码实践
- Javascript 使用function定义构造函数
- JQuery 将元素显示在屏幕的中央的代码
- JQuery团队打造的javascript单元测试工具QUnit介绍
- getElementsByTagName vs selectNodes效率 及兼容的selectNodes实现
- JavaScript 空位补零实现代码
- javascript replace()正则替换实现代码
- JavaScript 时分秒时间代码(自动补零)