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程序设计有所帮助。