您的位置:首页 > Web前端 > JavaScript

JS数据类型判断和数组类型判断

2015-04-22 15:27 417 查看

js六大数据类型:number、string、object、Boolean、null、undefinedstring: 由单引号或双引号来说明,如"string"number:什么整数啊浮点数啊都叫数字,你懂的~Boolean: 就是true和false啦undefined:未定义,就是你创建一个变量后却没给它赋值~null: 故名思久,null就是没有,什么也不表示object: 这个我也很难解释的说。就是除了上面五种之外的类型--------------------上面的都是浮云,下面的才是神马------------------------------数据类型判断之 typeof,但是不能判断数组类型,因为typeof(array)返回objecttypeof可以解决大部分的数据类型判断,是一个一元运算,放在一个运算值之前,其返回值为一个字符串,该字符串说明运算数的类型,所以判断某个是否为String类型,可以直接 if(typeof(你的值) == "string"){}以下是各种数据类型返回结果:
typeof "John"                // 返回 string
typeof 3.14                  // 返回 number
typeof false                 // 返回 boolean
var a;
typeof(a);                  //返回undefined
typeof [1,2,3,4] // 返回 objecttypeof {name:'John', age:34} // 返回 object
数组是一种特殊的对象类型。 因此 typeof [1,2,3,4] 返回 object。 null、对象、数组返回的都是object类型;
对于函数类型返回的则是function,再比如typeof(Date),typeof(eval)等。---------------------------------------其实这才是我的目的,咩~----------------------------------------------js判断数组类型的方法方法一之 instanceofinstance,故名思义,实例,例子,所以instanceof 用于判断一个变量是否某个对象的实例,是一个三目运算式---和typeof最实质上的区别ainstanceof b?alert("true"):alert("false") //注意b值是你想要判断的那种数据类型,不是一个字符串,比如Array举个栗子:
var a=[];console.log(a instanceof Array) //返回true 
方法二之 constructor在W3C定义中的定义:constructor 属性返回对创建此对象的数组函数的引用就是返回对象相对应的构造函数。从定义上来说跟instanceof不太一致,但效果都是一样的如: (a instanceof Array) //a是否Array的实例?true or false  (a.constructor == Array) // a实例所对应的构造函数是否为Array? true or false举个栗子:
function employee(name,job,born){this.name=name;this.job=job;this.born=born;}var bill=new employee("Bill Gates","Engineer",1985);console.log(bill.constructor); //输出function employee(name, jobtitle, born){this.name = name; this.jobtitle = job; this.born = born;}
那么判断各种类型的方法就是:
console.log([].constructor == Array);console.log({}.constructor == Object);console.log("string".constructor == String);console.log((123).constructor == Number);console.log(true.constructor == Boolean);
-------------------------------------以下不是原创--------------------------------------较为严谨并且通用的方法:
function isArray(object){return object && typeof object==='object' &&Array == object.constructor;}
!!注意:使用instaceof和construcor,被判断的array必须是在当前页面声明的!比如,一个页面(父页面)有一个框架,框架中引用了一个页面(子页面),在子页面中声明了一个array,并将其赋值给父页面的一个变量,这时判断该变量,Array == object.constructor;会返回false;原因:1、array属于引用型数据,在传递过程中,仅仅是引用地址的传递。2、每个页面的Array原生对象所引用的地址是不一样的,在子页面声明的array,所对应的构造函数,是子页面的Array对象;父页面来进行判断,使用的Array并不等于子页面的Array;切记,不然很难跟踪问题!方法三之 特性判断法!!!以上方法均有一定的缺陷,但要相信人民大众的智慧是无所不能及的,我们可根据数组的一些特性来判断其类型
function isArray(object){return  object && typeof object==='object' && typeof object.length==='number' &&typeof object.splice==='function' &&//判断length属性是否是可枚举的 对于数组 将得到false!(object.propertyIsEnumerable('length'));}
有length和splice并不一定是数组,因为可以为对象添加属性,而不能枚举length属性,才是最重要的判断因子。ps: 在这里普及下 propertyIsEnumerable 方法:
object. propertyIsEnumerable(proName)
判断指定的属性是否可列举备注:如果 proName 存在于 object 中且可以使用一个 For…In 循环穷举出来,那么 propertyIsEnumerable 属性返回 true。如果 object 不具有所指定的属性或者所指定的属性不是可列举的,那么 propertyIsEnumerable属性返回 false。propertyIsEnumerable 属性不考虑原型链中的对象。示例:
var a = new Array("apple", "banana", "cactus");document.write(a.propertyIsEnumerable(1));
方法四之 最简单的方法对于这种方法,以下有几个链接可供参考解释:/article/11590236.html/article/3561256.html/article/3981655.html
function isArray(o) {return Object.prototype.toString.call(o) === ‘[object Array]‘;}
当然,你知道啦,这篇东西不完全是出自我手的啦,所以参考文章还是要列一列的啦:http://www.2fz1.com/?p=277http://msdn.microsoft.com/zh-tw/library/adebfyya.aspxhttp://blog.sina.com.cn/s/blog_532751d90100iv1r.html转自http://www.cnblogs.com/mofish/p/3388427.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: