Welcome 微信登录

首页 / 脚本样式 / JavaScript / JavaScript知识点总结(六)之JavaScript判断变量数据类型

最近做了一个项目,其中有关于js判断数据类型的处理,在网上搜了相关资料,并且亲自测试了各种数据类型的判断,绝对安全。下面小编把具体内容总结分享给大家,大家参考下!

一、JS中的数据类型

1.数值型(Number):包括整数、浮点数。

2.布尔型(Boolean)

3.字符串型(String)

4.对象(Object)

5.数组(Array)

6.空值(Null)

7.未定义(Undefined)

二、判断一个变量的数据类型

1.数值型(number)

比较常用的判断方法是:

function isNumber(val){return typeof val === "number";} 
但有些情况就不行,比如:

var a;alert(isNumber(parseInt(a))); 
这里弹出来的是true,如下图所示:



但实际上变量a是NaN,它是不能用于数值运算的。

所以上面的函数可以修改为:

function isNumber(val){return typeof val === "number" && isFinite(val);} 
修改了之后,弹出来的就是false,如下图所示:


顺便介绍一下JavaScript isFinite() 函数,isFinite() 函数用于检查其参数是否是无穷大,如果 number 是有限数字(或可转换为有限数字),那么返回 true。否则,如果 number 是 NaN(非数字),或者是正、负无穷大的数,则返回 false。

2.布尔型(boolean)

布尔类型的判断比较简单,可以用如下的方法进行判断:

/*判断变量val是不是布尔类型*/function isBooleanType(val) {return typeof val ==="boolean";} 
测试代码:

<script type="text/javascript">/*判断变量val是不是布尔类型*/function isBooleanType(val) {return typeof val ==="boolean";}var a;var b = false;alert("变量a是布尔类型的判断结果是:"+isBooleanType(a));alert("变量b是布尔类型的判断结果是:"+isBooleanType(b));</script> 
运行结果:


3. 字符串(String)

字符串类型的判断比较简单,可以用如下的方法进行判断:

/*判断变量是不是字符串类型*/function isStringType(val) {return typeof val === "string";} 
测试代码:

<script type="text/javascript">/*判断变量是不是字符串类型*/function isStringType(val) {return typeof val === "string";}var a;var s = "strType";alert("变量a是字符串类型的判断结果是:"+isStringType(a));alert("变量s是字符串类型的判断结果是:"+isStringType(s));</script> 
运行结果:



4.未定义(Undefined)

未定义的判断比较简单,可以用如下的方法进行判断:

/*判断变量是不是Undefined*/function isUndefined(val) {return typeof val === "undefined";}
测试代码:

<script type="text/javascript">var a;//a是undefinedvar s = "strType";/*判断变量是不是Undefined*/function isUndefined(val) {return typeof val === "undefined";}alert("变量a是Undefined的判断结果是:"+isUndefined(a));alert("变量s是Undefined的判断结果是:"+isUndefined(s));</script> 
运行结果:



5.对象(Object)

由于当变量是空值Null时,typeof也会返回object,所以Object不能直接用 typeof 判断。

应该这样:

function isObj(str){if(str === null || typeof str === "undefined"){return false;}return typeof str === "object";} 
测试代码:
<script type="text/javascript">/*判断变量是不是Object类型*/function isObj(str){if(str === null || typeof str === "undefined"){return false;}return typeof str === "object";}var a;var b = null;var c = "str";var d = {};var e = new Object();alert("b的值是null,typeof b ==="object"的判断结果是:"+(typeof b ==="object"));alert("变量a是Object类型的判断结果是:"+isObj(a));//falsealert("变量b是Object类型的判断结果是:"+isObj(b));//falsealert("变量c是Object类型的判断结果是:"+isObj(c));//falsealert("变量d是Object类型的判断结果是:"+isObj(d));//truealert("变量e是Object类型的判断结果是:"+isObj(e));//true</script> 
运行结果:



6.空值(Null)

判断空值用 val === null 即可

function isNull(val){return val === null;}
测试代码:

/*判断变量是不是null*/function isNull(val){return val === null;}/*测试变量*/var a;var b = null;var c = "str";//弹出运行结果alert("变量a是null的判断结果是:"+isNull(a));//falsealert("变量b是null类型的判断结果是:"+isNull(b));//truealert("变量c是null类型的判断结果是:"+isNull(c));//false 
运行结果:



7.数组(Array)

数组类型不可用typeof来判断。因为当变量是数组类型是,typeof会返回object。

这里有两种方法判断数组类型:

/*判断变量arr是不是数组方法一*/function isArray(arr) {return Object.prototype.toString.apply(arr) === "[object Array]";}/*判断变量arr是不是数组方法二*/function isArray(arr) {if(arr === null || typeof arr === "undefined"){return false;}return arr.constructor === Array;}
测试代码:

<script type="text/javascript">/*判断变量arr是不是数组方法一*/function isArray(arr) {return Object.prototype.toString.apply(arr) === "[object Array]";}/*判断变量arr是不是数组方法二*/function isArray(arr) {if(arr === null || typeof arr === "undefined"){return false;}return arr.constructor === Array;}//测试变量var a = null;var b = "";var c ;var arr = [,,];var arr = new Array();//打印测试结果document.write("arr变量是数组类型,typeof arr === "object"的结果是:"+(typeof arr === "object"));document.write("<br/>");document.write("------------------------------------------------------------------------------------------------");document.write("<br/>");document.write("使用isArray方法判断结果如下:");document.write("<br/>");document.write("------------------------------------------------------------------------------------------------");document.write("<br/>");document.write("变量a是数组类型的判断结果是:"+isArray(a));document.write("<br/>");document.write("变量b是数组类型的判断结果是:"+isArray(b));document.write("<br/>");document.write("变量c是数组类型的判断结果是:"+isArray(c));document.write("<br/>");document.write("变量arr是数组类型的判断结果是:"+isArray(arr));document.write("<br/>");document.write("变量arr是数组类型的判断结果是:"+isArray(arr));document.write("<br/>");document.write("------------------------------------------------------------------------------------------------");document.write("<br/>");document.write("使用isArray方法判断结果如下:");document.write("<br/>");document.write("------------------------------------------------------------------------------------------------");document.write("<br/>");document.write("变量a是数组类型的判断结果是:"+isArray(a));document.write("<br/>");document.write("变量b是数组类型的判断结果是:"+isArray(b));document.write("<br/>");document.write("变量c是数组类型的判断结果是:"+isArray(c));document.write("<br/>");document.write("变量arr是数组类型的判断结果是:"+isArray(arr));document.write("<br/>");document.write("变量arr是数组类型的判断结果是:"+isArray(arr));document.write("<br/>");</script> 
运行结果:



以上内容是小编给大家介绍的JavaScript知识点总结(六)之JavaScript判断变量数据类型的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注脚本之家网站!