JavaScript学习总结(2)——JavaScript数据类型判断
来源:互联网 发布:java webp格式转换jpg 编辑:程序博客网 时间:2024/06/06 01:39
最近做项目中遇到了一些关于javascript数据类型的判断处理,上网找了一下资料,并且亲自验证了各种数据类型的判断,在此做一个总结吧!
一、JS中的数据类型
1.数值型(Number):包括整数、浮点数。
2.布尔型(Boolean)
3.字符串型(String)
4.对象(Object)
5.数组(Array)
6.空值(Null)
7.未定义(Undefined)
二、判断一个变量的数据类型
1.数值型(number)
比较常用的判断方法是:
1 function isNumber(val){2 return typeof val === 'number';3 }
但有些情况就不行,比如:
1 var a;2 alert(isNumber(parseInt(a)));
这里弹出来的是true,如下图所示:
但实际上变量a是NaN,它是不能用于数值运算的。
所以上面的函数可以修改为:
1 function isNumber(val){2 return typeof val === 'number' && isFinite(val);3 }
修改了之后,弹出来的就是false,如下图所示:
顺便介绍一下JavaScript isFinite() 函数,isFinite() 函数用于检查其参数是否是无穷大,如果 number 是有限数字(或可转换为有限数字),那么返回 true。否则,如果 number 是 NaN(非数字),或者是正、负无穷大的数,则返回 false。
2.布尔型(boolean)
布尔类型的判断比较简单,可以用如下的方法进行判断:
1 /*2 判断变量val是不是布尔类型3 */4 function isBooleanType(val) {5 return typeof val ==="boolean";6 }
测试代码:
1 <script type="text/javascript"> 2 /* 3 判断变量val是不是布尔类型 4 */ 5 function isBooleanType(val) { 6 return typeof val ==="boolean"; 7 } 8 var a; 9 var b = false;10 alert("变量a是布尔类型的判断结果是:"+isBooleanType(a));11 alert("变量b是布尔类型的判断结果是:"+isBooleanType(b));12 </script>
运行结果:
3. 字符串(String)
字符串类型的判断比较简单,可以用如下的方法进行判断:
1 /*2 判断变量是不是字符串类型3 */4 function isStringType(val) {5 return typeof val === "string";6 }
测试代码:
1 <script type="text/javascript"> 2 /* 3 判断变量是不是字符串类型 4 */ 5 function isStringType(val) { 6 return typeof val === "string"; 7 } 8 9 var a;10 var s = "strType";11 alert("变量a是字符串类型的判断结果是:"+isStringType(a));12 alert("变量s是字符串类型的判断结果是:"+isStringType(s));13 </script>
运行结果:
4.未定义(Undefined)
未定义的判断比较简单,可以用如下的方法进行判断:
1 /*2 判断变量是不是Undefined3 */4 function isUndefined(val) {5 return typeof val === "undefined";6 }
测试代码:
1 <script type="text/javascript"> 2 var a;//a是undefined 3 var s = "strType"; 4 /* 5 判断变量是不是Undefined 6 */ 7 function isUndefined(val) { 8 return typeof val === "undefined"; 9 }10 alert("变量a是Undefined的判断结果是:"+isUndefined(a));11 alert("变量s是Undefined的判断结果是:"+isUndefined(s));12 </script>
运行结果:
5.对象(Object)
由于当变量是空值Null时,typeof也会返回object,所以Object不能直接用 typeof 判断。
应该这样:
1 function isObj(str){2 if(str === null || typeof str === 'undefined'){3 return false;4 }5 return typeof str === 'object';6 }
测试代码:
1 <script type="text/javascript"> 2 /* 3 判断变量是不是Object类型 4 */ 5 function isObj(str){ 6 if(str === null || typeof str === 'undefined'){ 7 return false; 8 } 9 return typeof str === 'object';10 }11 12 var a;13 var b = null;14 var c = "str";15 var d = {};16 var e = new Object();17 18 alert("b的值是null,typeof b ==='object'的判断结果是:"+(typeof b ==='object'));19 alert("变量a是Object类型的判断结果是:"+isObj(a));//false20 alert("变量b是Object类型的判断结果是:"+isObj(b));//false21 alert("变量c是Object类型的判断结果是:"+isObj(c));//false22 alert("变量d是Object类型的判断结果是:"+isObj(d));//true23 alert("变量e是Object类型的判断结果是:"+isObj(e));//true24 </script>
运行结果:
6.空值(Null)
判断空值用 val === null 即可
1 function isNull(val){2 return val === null;3 }
测试代码:
1 /* 2 判断变量是不是null 3 */ 4 function isNull(val){ 5 return val === null; 6 } 7 /*测试变量*/ 8 var a; 9 var b = null;10 var c = "str";11 //弹出运行结果12 alert("变量a是null的判断结果是:"+isNull(a));//false13 alert("变量b是null类型的判断结果是:"+isNull(b));//true14 alert("变量c是null类型的判断结果是:"+isNull(c));//false
运行结果:
7.数组(Array)
数组类型不可用typeof来判断。因为当变量是数组类型是,typeof会返回object。
这里有两种方法判断数组类型:
1 /*判断变量arr是不是数组 2 方法一 3 */ 4 function isArray1(arr) { 5 return Object.prototype.toString.apply(arr) === '[object Array]'; 6 } 7 8 /*判断变量arr是不是数组 9 方法二10 */11 function isArray2(arr) {12 if(arr === null || typeof arr === 'undefined'){13 return false;14 }15 return arr.constructor === Array;16 }
测试代码:
1 <script type="text/javascript"> 2 /*判断变量arr是不是数组 3 方法一 4 */ 5 function isArray1(arr) { 6 return Object.prototype.toString.apply(arr) === '[object Array]'; 7 } 8 /*判断变量arr是不是数组 9 方法二10 */11 function isArray2(arr) {12 if(arr === null || typeof arr === 'undefined'){13 return false;14 }15 return arr.constructor === Array;16 }17 //测试变量18 var a = null;19 var b = "";20 var c ;21 var arr1 = [1,2,3];22 var arr2 = new Array();23 //打印测试结果24 document.write("arr1变量是数组类型,typeof arr1 === 'object'的结果是:"+(typeof arr1 === 'object'));25 document.write("<br/>");26 document.write("------------------------------------------------------------------------------------------------");27 document.write("<br/>");28 document.write("使用isArray1方法判断结果如下:");29 document.write("<br/>");30 document.write("------------------------------------------------------------------------------------------------");31 document.write("<br/>");32 document.write("变量a是数组类型的判断结果是:"+isArray1(a));33 document.write("<br/>");34 document.write("变量b是数组类型的判断结果是:"+isArray1(b));35 document.write("<br/>");36 document.write("变量c是数组类型的判断结果是:"+isArray1(c));37 document.write("<br/>");38 document.write("变量arr1是数组类型的判断结果是:"+isArray1(arr1));39 document.write("<br/>");40 document.write("变量arr2是数组类型的判断结果是:"+isArray1(arr2));41 document.write("<br/>");42 document.write("------------------------------------------------------------------------------------------------");43 document.write("<br/>");44 document.write("使用isArray2方法判断结果如下:");45 document.write("<br/>");46 document.write("------------------------------------------------------------------------------------------------");47 document.write("<br/>");48 document.write("变量a是数组类型的判断结果是:"+isArray2(a));49 document.write("<br/>");50 document.write("变量b是数组类型的判断结果是:"+isArray2(b));51 document.write("<br/>");52 document.write("变量c是数组类型的判断结果是:"+isArray2(c));53 document.write("<br/>");54 document.write("变量arr1是数组类型的判断结果是:"+isArray2(arr1));55 document.write("<br/>");56 document.write("变量arr2是数组类型的判断结果是:"+isArray2(arr2));57 document.write("<br/>");58 </script>
运行结果:
分类: JavaScript标签: Javascript学习总结好文要顶 关注我 收藏该文 150(请您对文章做出评价)« 上一篇:java基础学习总结——接口
» 下一篇:JavaScript学习总结(五)——Javascript中==和===的区别
posted on 2014-04-16 00:56 孤傲苍狼 阅读(2598) 评论(14) 编辑 收藏
最近做项目中遇到了一些关于javascript数据类型的判断处理,上网找了一下资料,并且亲自验证了各种数据类型的判断,在此做一个总结吧!
一、JS中的数据类型
1.数值型(Number):包括整数、浮点数。
2.布尔型(Boolean)
3.字符串型(String)
4.对象(Object)
5.数组(Array)
6.空值(Null)
7.未定义(Undefined)
二、判断一个变量的数据类型
1.数值型(number)
比较常用的判断方法是:
1 function isNumber(val){2 return typeof val === 'number';3 }
但有些情况就不行,比如:
1 var a;2 alert(isNumber(parseInt(a)));
这里弹出来的是true,如下图所示:
但实际上变量a是NaN,它是不能用于数值运算的。
所以上面的函数可以修改为:
1 function isNumber(val){2 return typeof val === 'number' && isFinite(val);3 }
修改了之后,弹出来的就是false,如下图所示:
顺便介绍一下JavaScript isFinite() 函数,isFinite() 函数用于检查其参数是否是无穷大,如果 number 是有限数字(或可转换为有限数字),那么返回 true。否则,如果 number 是 NaN(非数字),或者是正、负无穷大的数,则返回 false。
2.布尔型(boolean)
布尔类型的判断比较简单,可以用如下的方法进行判断:
1 /*2 判断变量val是不是布尔类型3 */4 function isBooleanType(val) {5 return typeof val ==="boolean";6 }
测试代码:
1 <script type="text/javascript"> 2 /* 3 判断变量val是不是布尔类型 4 */ 5 function isBooleanType(val) { 6 return typeof val ==="boolean"; 7 } 8 var a; 9 var b = false;10 alert("变量a是布尔类型的判断结果是:"+isBooleanType(a));11 alert("变量b是布尔类型的判断结果是:"+isBooleanType(b));12 </script>
运行结果:
3. 字符串(String)
字符串类型的判断比较简单,可以用如下的方法进行判断:
1 /*2 判断变量是不是字符串类型3 */4 function isStringType(val) {5 return typeof val === "string";6 }
测试代码:
1 <script type="text/javascript"> 2 /* 3 判断变量是不是字符串类型 4 */ 5 function isStringType(val) { 6 return typeof val === "string"; 7 } 8 9 var a;10 var s = "strType";11 alert("变量a是字符串类型的判断结果是:"+isStringType(a));12 alert("变量s是字符串类型的判断结果是:"+isStringType(s));13 </script>
运行结果:
4.未定义(Undefined)
未定义的判断比较简单,可以用如下的方法进行判断:
1 /*2 判断变量是不是Undefined3 */4 function isUndefined(val) {5 return typeof val === "undefined";6 }
测试代码:
1 <script type="text/javascript"> 2 var a;//a是undefined 3 var s = "strType"; 4 /* 5 判断变量是不是Undefined 6 */ 7 function isUndefined(val) { 8 return typeof val === "undefined"; 9 }10 alert("变量a是Undefined的判断结果是:"+isUndefined(a));11 alert("变量s是Undefined的判断结果是:"+isUndefined(s));12 </script>
运行结果:
5.对象(Object)
由于当变量是空值Null时,typeof也会返回object,所以Object不能直接用 typeof 判断。
应该这样:
1 function isObj(str){2 if(str === null || typeof str === 'undefined'){3 return false;4 }5 return typeof str === 'object';6 }
测试代码:
1 <script type="text/javascript"> 2 /* 3 判断变量是不是Object类型 4 */ 5 function isObj(str){ 6 if(str === null || typeof str === 'undefined'){ 7 return false; 8 } 9 return typeof str === 'object';10 }11 12 var a;13 var b = null;14 var c = "str";15 var d = {};16 var e = new Object();17 18 alert("b的值是null,typeof b ==='object'的判断结果是:"+(typeof b ==='object'));19 alert("变量a是Object类型的判断结果是:"+isObj(a));//false20 alert("变量b是Object类型的判断结果是:"+isObj(b));//false21 alert("变量c是Object类型的判断结果是:"+isObj(c));//false22 alert("变量d是Object类型的判断结果是:"+isObj(d));//true23 alert("变量e是Object类型的判断结果是:"+isObj(e));//true24 </script>
运行结果:
6.空值(Null)
判断空值用 val === null 即可
1 function isNull(val){2 return val === null;3 }
测试代码:
1 /* 2 判断变量是不是null 3 */ 4 function isNull(val){ 5 return val === null; 6 } 7 /*测试变量*/ 8 var a; 9 var b = null;10 var c = "str";11 //弹出运行结果12 alert("变量a是null的判断结果是:"+isNull(a));//false13 alert("变量b是null类型的判断结果是:"+isNull(b));//true14 alert("变量c是null类型的判断结果是:"+isNull(c));//false
运行结果:
7.数组(Array)
数组类型不可用typeof来判断。因为当变量是数组类型是,typeof会返回object。
这里有两种方法判断数组类型:
1 /*判断变量arr是不是数组 2 方法一 3 */ 4 function isArray1(arr) { 5 return Object.prototype.toString.apply(arr) === '[object Array]'; 6 } 7 8 /*判断变量arr是不是数组 9 方法二10 */11 function isArray2(arr) {12 if(arr === null || typeof arr === 'undefined'){13 return false;14 }15 return arr.constructor === Array;16 }
测试代码:
1 <script type="text/javascript"> 2 /*判断变量arr是不是数组 3 方法一 4 */ 5 function isArray1(arr) { 6 return Object.prototype.toString.apply(arr) === '[object Array]'; 7 } 8 /*判断变量arr是不是数组 9 方法二10 */11 function isArray2(arr) {12 if(arr === null || typeof arr === 'undefined'){13 return false;14 }15 return arr.constructor === Array;16 }17 //测试变量18 var a = null;19 var b = "";20 var c ;21 var arr1 = [1,2,3];22 var arr2 = new Array();23 //打印测试结果24 document.write("arr1变量是数组类型,typeof arr1 === 'object'的结果是:"+(typeof arr1 === 'object'));25 document.write("<br/>");26 document.write("------------------------------------------------------------------------------------------------");27 document.write("<br/>");28 document.write("使用isArray1方法判断结果如下:");29 document.write("<br/>");30 document.write("------------------------------------------------------------------------------------------------");31 document.write("<br/>");32 document.write("变量a是数组类型的判断结果是:"+isArray1(a));33 document.write("<br/>");34 document.write("变量b是数组类型的判断结果是:"+isArray1(b));35 document.write("<br/>");36 document.write("变量c是数组类型的判断结果是:"+isArray1(c));37 document.write("<br/>");38 document.write("变量arr1是数组类型的判断结果是:"+isArray1(arr1));39 document.write("<br/>");40 document.write("变量arr2是数组类型的判断结果是:"+isArray1(arr2));41 document.write("<br/>");42 document.write("------------------------------------------------------------------------------------------------");43 document.write("<br/>");44 document.write("使用isArray2方法判断结果如下:");45 document.write("<br/>");46 document.write("------------------------------------------------------------------------------------------------");47 document.write("<br/>");48 document.write("变量a是数组类型的判断结果是:"+isArray2(a));49 document.write("<br/>");50 document.write("变量b是数组类型的判断结果是:"+isArray2(b));51 document.write("<br/>");52 document.write("变量c是数组类型的判断结果是:"+isArray2(c));53 document.write("<br/>");54 document.write("变量arr1是数组类型的判断结果是:"+isArray2(arr1));55 document.write("<br/>");56 document.write("变量arr2是数组类型的判断结果是:"+isArray2(arr2));57 document.write("<br/>");58 </script>
运行结果:
» 下一篇:JavaScript学习总结(五)——Javascript中==和===的区别
posted on 2014-04-16 00:56 孤傲苍狼 阅读(2598) 评论(14) 编辑 收藏
- JavaScript学习总结(2)——JavaScript数据类型判断
- JavaScript学习总结(六)——JavaScript判断数据类型总结
- JavaScript学习总结(六)——JavaScript判断数据类型总结
- JavaScript学习总结(六)——JavaScript判断数据类型总结
- JavaScript判断数据类型总结
- Javascript学习总结--数据类型
- 学习总结-javascript数据类型详解
- JavaScript——判断js数据类型(类型检测)
- JavaScript基础(2)——JavaScript的数据类型
- javascript判断数据类型
- javascript判断数据类型
- 判断JavaScript的数据类型
- JavaScript判断数据类型
- JavaScript数据类型判断
- javaScript判断数据类型
- JavaScript数据类型及其判断
- JavaScript判断数据类型
- javascript判断数据类型
- java 坦克大战2.0版
- Seaborn使用说明
- 前篇:1.公共技术点之面向对象六大原则
- linux 信号
- 解密Linux kernel中的内核线程
- JavaScript学习总结(2)——JavaScript数据类型判断
- matlab中max的用法
- 专访DroidPlugin作者张勇:安卓黑科技是怎样炼成的
- linux C语言实现文件锁
- lua实现一个2048小游戏
- SSH秘钥生成
- iOS使用NSMutableAttributedString 实现富文本(不同颜色字体、下划线等)
- linux之sed用法
- NSIS DirectUI界面 nsSkinEngine 插件,让安装包不再枯燥,一键打包!!http://www.aceui.cn/
评论
#1楼 2014-04-16 08:27 codezyc
很实用,谢谢分享。
#2楼 2014-04-16 09:02 网络白蚁
果断收藏。
#3楼 2014-04-16 09:08 winpzs
你确定所有浏览器都合适?IE6?IE7?
#4楼 2014-04-16 09:08 objectboy
额,这个两个"=" 和三个"=" 啥区别,求指教,我基础太差啦 ,为啥要用三个"=" 呢
#5楼 2014-04-16 09:18 winpzs
var
testType = {
isType:
function
(typename, value) {
//typename:String, Array, Boolean, Object, RegExp, Date, Function,Number //兼容
//typename:Null, Undefined,Arguments //IE不兼容
return
Object.prototype.toString.apply(value) ===
'[object '
+ typename +
']'
;
},
isUndefined:
function
(obj) {
///<summary>是否定义</summary>
return
(
typeof
(obj) ===
"undefined"
|| obj === undefined);
},
isNull:
function
(obj) {
///<summary>是否Null</summary>
return
(obj ===
null
||
this
.isUndefined(obj));
},
isBoolean:
function
(obj) {
return
this
.isType(
"Boolean"
, obj);
},
isObjectEmpty:
function
(obj) {
if
(
this
.isNull(obj))
return
true
;
for
(
var
n
in
obj) {
if
(!obj.hasOwnProperty(n))
continue
;
return
false
;
}
return
true
;
},
isNullEmpty:
function
(s) {
return
(
this
.isNull(s) || s ===
''
);
},
isFunction:
function
(fun) {
return
this
.isType(
"Function"
, fun);
},
isNumeric:
function
(n) {
//return this.isType("Number", n) && !isNaN(n) && isFinite(n);;
return
!isNaN(parseFloat(n)) && isFinite(n);
},
isString:
function
(obj) {
return
this
.isType(
"String"
, obj);
},
isObject:
function
(obj) {
return
!
this
.isNull(obj) &&
this
.isType(
"Object"
, obj);
},
isArray:
function
(value) {
return
Array.isArray ? Array.isArray(value) :
this
.isType(
"Array"
, value);
},
isJquery:
function
(obj) {
return
(obj
instanceof
window.jQuery);
},
isWindow:
function
(obj) {
return
!
this
.isNull(obj) && obj == obj.window },
isElement:
function
(obj) {
var
t = obj && (obj.ownerDocument || obj).documentElement;
return
t ?
true
:
false
}
};