javascript数据类型验证方法
最近对javascript数据类型的验证又有了一个新的认识,原来可以判断得这么简单又如此全面。
我们自定义了isString,isNumber,isDate,isError,isRegExp,isBoolean,isNull,isUndefined,isObject等方法。现在将自己定义的javascript数据类型验证函数及测试集展示:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf-8">
<title></title>
</head>
<body>
</body>
<scripttype="text/javascript">
//isString
//isNumber
//isDate
//isError
//isRegExp
//直接利用和数据类型来判断
[].forEach.call(['String','Number','Date','Error','RegExp'],function(name){
this['is'+name]=function(obj){
returntoString.call(obj)==='[object'+name+']';
};
});
//isBoolean
//true和false需要考虑在内
Object.prototype.isBoolean=function(obj){
returnobj===true||obj===false||toString.call(obj)==='[objectBoolean]';
};
//isNull
//未找到所指向对象
Object.prototype.isNull=function(obj){
returnobj===null;
};
//isUndefined
//定义了但是未赋值
Object.prototype.isUndefined=function(obj){
returnobj===void0;
};
//isObject
//函数和数组都是对象
Object.prototype.isObject=function(obj){
vartype=typeofobj;
returntype==='function'||type==='object'&&!!obj;
};
//test
//isString
varstr="iamstring";
vara=isString(str);
console.log(a);//true
//isNumber
varb=isNumber(a);
console.log(b);//false
//isNumber
varnum=4;
varc=isNumber(num);
console.log(c);//true
//isRegExp
varreg=/^[1-9]/;
vard=isRegExp(reg);
console.log(d);//true
//isDate
vardate=newDate();
vare=isDate(date);
console.log(e);//true
//isBoolean
varbool=false;
varf=isBoolean(bool);
console.log(f);//true
//isNull
varnul=document.getElementById("div02");
varg=isNull(nul);
console.log(g);//true
//isUndefined
varundef;
varh=isUndefined(undef);
console.log(h);//true
//isObject
varobj={"1":"1","2":"2"};
vari=isObject(obj);
console.log(i);//true
</script>
</html>
以下主要是对判断javascript的数据类型进行了详细的介绍,分为六种数据类型,需要的朋友可以过来参考下,希望对大家有所帮助
1、判断是否为数组类型
代码如下:
<STRONG><scripttype="text/javascript">
//<![CDATA[
vara=[0];
document.write(isArray(a),'<br/>');
functionisArray(obj){
return(typeofobj=='object')&&obj.constructor==Array;
}
//]]>
</script></STRONG>
2判断是否为字符串类型
代码如下:
<scripttype="text/javascript">
//<![CDATA[
document.write(isString('test'),'<br/>');
document.write(isString(10),'<br/>');
functionisString(str){
return(typeofstr=='string')&&str.constructor==String;
}
//]]>
</script>
3判断是否为数值类型
代码如下:
<scripttype="text/javascript">
//<![CDATA[
document.write(isNumber('test'),'<br/>');
document.write(isNumber(10),'<br/>');
functionisNumber(obj){
return(typeofobj=='number')&&obj.constructor==Number;
}
//]]>
</script>
4判断是否为日期类型
代码如下:
<scripttype="text/javascript">
//<![CDATA[
document.write(isDate(newDate()),'<br/>');
document.write(isDate(10),'<br/>');
functionisDate(obj){
return(typeofobj=='object')&&obj.constructor==Date;
}
//]]>
</script>
5判断是否为函数
代码如下:
<scripttype="text/javascript">
//<![CDATA[
document.write(isFunction(functiontest(){}),'<br/>');
document.write(isFunction(10),'<br/>');
functionisFunction(obj){
return(typeofobj=='function')&&obj.constructor==Function;
}
//]]>
</script>
6判断是否为对象
代码如下:
<scripttype="text/javascript">
linenum
//<![CDATA[
document.write(isObject(newObject()),'<br/>');
document.write(isObject(10),'<br/>');
functionisObject(obj){
return(typeofobj=='object')&&obj.constructor==Object;
}
//]]>
</script>
希望本文所述对大家学习javascript程序设计有所帮助。