JavaScript学习总结(2)——JavaScript数据类型判断
最近做项目中遇到了一些关于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 判断变量是不是Undefined
3 */
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));//false
20 alert("变量b是Object类型的判断结果是:"+isObj(b));//false
21 alert("变量c是Object类型的判断结果是:"+isObj(c));//false
22 alert("变量d是Object类型的判断结果是:"+isObj(d));//true
23 alert("变量e是Object类型的判断结果是:"+isObj(e));//true
24 </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));//false
13 alert("变量b是null类型的判断结果是:"+isNull(b));//true
14 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学习总结
评论
#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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
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 }
};
最近做项目中遇到了一些关于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 判断变量是不是Undefined
3 */
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));//false
20 alert("变量b是Object类型的判断结果是:"+isObj(b));//false
21 alert("变量c是Object类型的判断结果是:"+isObj(c));//false
22 alert("变量d是Object类型的判断结果是:"+isObj(d));//true
23 alert("变量e是Object类型的判断结果是:"+isObj(e));//true
24 </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));//false
13 alert("变量b是null类型的判断结果是:"+isNull(b));//true
14 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>

运行结果:
评论
#1楼 2014-04-16
08:27 codezyc
|
#2楼 2014-04-16
09:02 网络白蚁
|
#3楼 2014-04-16
09:08 winpzs
|
#4楼 2014-04-16
09:08 objectboy
|
#5楼 2014-04-16
09:18 winpzs
|
JavaScript学习总结(2)——JavaScript数据类型判断的更多相关文章
- JavaScript学习(1)之JavaScript基础
JavaScript学习(1)之JavaScript基础 由于工作原因,开发语言逐渐以JavaScript为主,所以,抽空学习了下JavaScript语法.等现阶段的工作稳定之后,陆续会分享下自己在学 ...
- Javascript学习笔记1 javascript的特点
..对于网页而言,Javascript无处不在,对于英语不好的人它简直是噩梦般的存在,但形式所逼,今天开始着手学习!希望自己能坚持下去.从什么地方着手,我的目标是从大处着眼,从应用着眼,不抠细节,反正 ...
- JavaScript学习总结(一)——JavaScript基础
一.JavaScript语言特点 1.1.JavaScript是基于对象和事件驱动的(动态的) 它可以直接对用户或客户输入做出响应,无须经过Web服务程序.它对用户的响应,是采用以事件驱动的方式进行的 ...
- Javascript学习笔记3 Javascript与BOM简介
什么是BOM BOM是browser object model的缩写,简称浏览器对象模型 BOM提供了独立于内容而与浏览器窗口进行交互的对象 由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心对象 ...
- JavaScript学习笔记(4)——JavaScript语法之变量
一.变量可以使用短名称(比如 x 和 y),也可以使用描述性更好的名称(比如 age, sum, totalvolume). 变量必须以字母开头 变量也能以 $ 和 _ 符号开头(不过我们不推荐这么做 ...
- JavaScript学习总结(六)——JavaScript判断数据类型总结
最近做项目中遇到了一些关于javascript数据类型的判断处理,上网找了一下资料,并且亲自验证了各种数据类型的判断,在此做一个总结吧! 一.JS中的数据类型 1.数值型(Number):包括整数.浮 ...
- JavaScript学习笔记——变量和数据类型
一.javascript命名规范 1. 严格区分大小写 2. 变量的命名必须以字母或 _或 $开头,余下的部分可以是任意的字母,数字,或者是 _或者是$ 3.不能用关键字或者是保留字命名. 4.jav ...
- javascript中的真假值、数据类型判断以及+的特殊用法
一.javascript中的假值 jQuery中拥有一组数量奇大的假值,包括 0,NaN(非数),''(空字符串),false,null,undefined 这些值在if判断中全部等于假,但这些值彼此 ...
- Javascript学习笔记-基本概念-数据类型
1.typeof 操作符的返回值: "undefined"——如果这个值未定义: "boolean"——如果这个值是布尔值: "string" ...
- JavaScript学习笔记(5)——JavaScript语法之数据类型
JavaScript 拥有动态类型.这意味着相同的变量可用作不同的类型: var x // x 为 undefined var x = 6; // x 为数字 var x = "Bill&q ...
随机推荐
- 维护的JSP站点数据丢失
两个月前换了份工作,然后接手了三台server.上面乱七八糟的网站和应用大把. 当中有维护一个瀚石苑:http://www.hanshiyuan.com/.三天两头的丢失数据. 都不知道怎么找回,好在 ...
- HDU 5379 Mahjong tree dfs+组合数学
题意:给你一棵树来分配号码,要求是兄弟节点连续并且每一棵子树连续. 思路:因为要求兄弟和子树都是连续的,所以自己打下草稿就可以发现如果一个节点有3个或3个以上的非叶子结点,那么就无论如何也不能达到目的 ...
- HDU 5375 Gray Code 动归
题意:给你一串不确定的二进制码,其对应的格雷码的每一位有对应的权值,问转换成的格雷码的能取到的最大权值是多少. 思路:没有思路,乱搞也AC #pragma comment(linker, " ...
- 多路径软件常用操作(MPIO)
一:查看存储盘的路径 1. 查看MPIO的存储盘的路径 # lspath (适用于所有存储的MPIO路径查询) # mpio_get_config -Av (适用于DS3K/DS4K的MPIO路径查询 ...
- 威联通 移动硬盘路径 /share/USBDisk1
威联通 移动硬盘路径 /share/USBDisk1 cd /share/USBDisk3/Movies
- Yeslab 华为安全HCIE-第五门-防火墙攻击防范技术
Yeslab 华为安全HCIE-第五门-防火墙攻击防范技术 课程目录 Yeslab华为安全HCIE-第五门-防火墙攻击防范技术(8篇)\1_单包攻击防范.aviYeslab华为安全HCIE-第五门-防 ...
- mkdi---创建目录。
mkdir命令用来创建目录.该命令创建由dirname命名的目录.如果在目录名的前面没有加任何路径名,则在当前目录下创建由dirname指定的目录:如果给出了一个已经存在的路径,将会在该目录下创建一个 ...
- 【python 设计模式】单例模式
单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在.当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场. 比如,某 ...
- SpringBoot 静态资源 加载位置
1.配置自定义拦截器 /** * Copyright (C), 2017-2018, XXX有限公司 * FileName: WebConfig * Author: 丶Zh1Guo * Date: 2 ...
- UESTC 360 Another LCIS
Another LCIS Time Limit: 1000ms Memory Limit: 65536KB This problem will be judged on UESTC. Original ...
