js数据类型及判断

一:六大数据类型:

js六大数据类型:number、string、object、Boolean、null、undefined

string: 由单引号或双引号来说明,如"string"

number:什么整数啊浮点数啊都叫数字

Boolean: 就是true和false啦

undefined:未定义,就是你创建一个变量后却没给它赋值~

null: 故名思久,null就是没有,什么也不表示

object: 就是除了上面五种之外的类型 万物皆对象’

二:数据类型判断之typeof

typeof是一个一元运算,放在一个运算值之前,其返回值为一个字符串,该字符串说明运算数的类型,所以判断某个是否为String类型,可以直接 if(typeof(你的值) == "string"){}

null、对象、数组返回的都是object类

函数类型返回的则是function,再比如typeof(Date),typeof(eval)

三:判断数组类型之instanceof

1::::instanceof是一个三目运算式---和typeof最实质上的区别

a instanceof b?alert("true"):alert("false")//注意b值是你想要判断的那种数据类型,不是一个字符串,比如Array  (a  instanceof    Array)

2::Array.isArray(obj)

四:constructor

constructor 属性返回对创建此对象的数组函数的引用  ,就是返回对象相对应的构造函数

(a.constructor == Array)  // a实例所对应的构造函数是否为Array? true or false

!!注意:

使用instaceof和construcor,被判断的array必须是在当前页面声明的!比如,一个页面(父页面)有一个框架,框架中引用了一个页面(子页面),在子页面中声明了一个array,并将其赋值给父页面的一个变量,这时判断该变量,Array == object.constructor;会返回false;

原因:

1、array属于引用型数据,在传递过程中,仅仅是引用地址的传递。

2、每个页面的Array原生对象所引用的地址是不一样的,在子页面声明的array,所对应的构造函数,是子页面的Array对象;父页面来进行判断,使用的Array并不等于子页面的Array;切记,不然很难跟踪问题!

五:propertyIsEnumerable 方法:

object. propertyIsEnumerable(proName)    判断指定的属性是否可列举

proName 存在于 object 中且可以使用一个 For…In 循环穷举出来,那么 propertyIsEnumerable 属性返回 true。如果 object 不具有所指定的属性或者所指定的属性不是可列举的,那么 propertyIsEnumerable 属性返回 false。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容