最近做了一个项目,其中有关于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是undefined var 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));//false alert("变量b是Object类型的判断结果是:"+isObj(b));//false alert("变量c是Object类型的判断结果是:"+isObj(c));//false alert("变量d是Object类型的判断结果是:"+isObj(d));//true alert("变量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));//false alert("变量b是null类型的判断结果是:"+isNull(b));//true alert("变量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判断变量数据类型的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注小牛知识库网站!
本文向大家介绍Javascript基础知识盲点总结之函数,包括了Javascript基础知识盲点总结之函数的使用技巧和注意事项,需要的朋友参考一下 函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。本文重点给大家介绍js基础知识盲点总结之函数。 一、函数中的arguments对象 每个函数内部都有一个arguments,它能返回函数所接受的所有参数 注意:argumens接收的是实参 如
本文向大家介绍JavaScript中判断数据类型的方法总结,包括了JavaScript中判断数据类型的方法总结的使用技巧和注意事项,需要的朋友参考一下 typeof typeof用的比较多的时候,是判断某个全局变量在不在,假如某个页面定义了一个全局变量。假如你做如下判断: 解决的方法是我们如下写: 用了typeof之后,就不会报错了!这是typeof的应用之一! 此外,typeof还可以进行数据类
本文向大家介绍JavaScript入门系列之知识点总结,包括了JavaScript入门系列之知识点总结的使用技巧和注意事项,需要的朋友参考一下 JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网
本文向大家介绍JavaScript知识点总结(十)之this关键字,包括了JavaScript知识点总结(十)之this关键字的使用技巧和注意事项,需要的朋友参考一下 this是Javascript语言的一个关键字。随着函数使用场合的不同,this的值会发生变化。但是有一个总的原则,那就是this指的是,调用函数的那个对象。JavaScript中的this指针是一个动态的变量,一个方法内的this
本文向大家介绍javaScript知识点总结(必看篇),包括了javaScript知识点总结(必看篇)的使用技巧和注意事项,需要的朋友参考一下 1、javaScript的概念:是一种表述语言,也是一种基于对象(Object)和事件驱动(EventDriven)的,安全性好的脚本语言,运行在客户端,从而减轻服务器端的负担,总结如下: 1.javaScript主要用来向HTML页面找那个添加交互行
本文向大家介绍JavaScript知识点总结之如何提高性能,包括了JavaScript知识点总结之如何提高性能的使用技巧和注意事项,需要的朋友参考一下 JavaScript的性能问题不容小觑,这就需要我们开发人员在编写JavaScript程序时多注意一些细节,本文非常详细的介绍了一下JavaScript性能优化方面的知识点,绝对是干货。 先给大家巩固下javascript基本语法: javascr