常见问题当前位置:天恒娱乐 > 常见问题 > >

天恒娱乐平台:Javascript如何判断数据类型和数组类

  

[Javascript,判断,数据类型,数组类型,typeof]Javascript如何判断数据类型和数组类型

  

这么基础的东西实在不应该再记录了,不过嘛,温故知新~就先从数据类型开始吧  

  

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

  

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

  

number:什么整数啊浮点数啊都叫数字,你懂的~  

  

Boolean: 就是true和false啦  

  

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

  

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

  

object: 这个我也很难解释的说。就是除了上面五种之外的类型  

  

------天恒娱乐--------------上面的都是浮云,下面的才是神马------------------------------  

  

数据类型判断之 typeof  

  

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

  

以下是各种数据类型返回结果:  
  

  
  
  var a="string"; console.log(a); //string  var a=1; console.log(a); //number  var a=false; console.log(a); //boolean  var a; console.log(typeof a); //undfined  var a = null; console.log(typeof a); //object  var a = document; console.log(typeof a); //object  var a = []; console.log(a); //object  var a = function(){}; console.log(typeof a) //function 除了可以判断数据类型还可以判断function类型  
  
  

这样一来就很明显了,除了前四个类型外,null、对象、数组返回的都是object类型;  

  

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

  

  

然后这里就可以再引申出另一个灰常热门并且解决方法已普遍存在的问题,如何判断数据是个数组类型?

  

  

---------------------------------------其实这才是我的目的,咩~----------------------------------------------  

  

js判断数组类型的方法  

  

方法一之 instanceof  

  

instance,故名思义,实例,例子,所以instanceof 用于判断一个变量是否某个对象的实例,是一个三目运算式---和typeof最实质上的区别  

  

a instanceof 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;   (责任编辑:admin)

上一篇:jquery禁止回车触发表单提交

下一篇:没有了

推荐内容