首頁 >web前端 >js教程 >如何判斷js資料型別與陣列的方法實例詳解

如何判斷js資料型別與陣列的方法實例詳解

伊谢尔伦
伊谢尔伦原創
2017-07-18 11:37:221697瀏覽

資料型別判斷之typeof

typeof可以解決大部分資料型別的判斷,其傳回值為一個字串,該字串說明運算數的型別。


//判断变量num是不是一个数字类型
if(typeof num=='number') {
  return true;
}

傳回結果:


#
var a="hling"; 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类型

除了string、number、boolean、undefined這四個類型外,null、object、array回傳的都是object類型! ! !

對於函數類型傳回的則是function,再例如typeof(Date),typeof(eval)等。

js判斷陣列類型的方法

#1) instanceof

instanceof 用來判斷一個變數是否某個物件的實例,是一個三目運算式。這個操作符和JavaScript中物件導向有點關係,了解這個就先得了解JavaScript中的物件導向。因為這個操作符是檢測物件的原型鍊是否指向建構函數的prototype物件的。


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

範例:


#
var arr = [1,2,3,1]; 
alert(arr instanceof Array); // true

2) constructor

在W3C定義中的定義:constructor 屬性傳回對建立此物件的陣列函數的參考


var arr = []; 
arr instanceof Array; // true 
arr.constructor == Array; //true

判斷各種類型的方法是:


console.log("string".constructor == String);
console.log((123).constructor == Number);
console.log(false.constructor == Boolean);
console.log([].constructor == Array);
console.log({}.constructor == Object);

通用的方法:


#
function isArray(object){
  return object && typeof object==='object' &&
      Array == object.constructor;
}

3) 特性判斷



############### ###object.isArray() 來判斷,目的就是要準確地偵測一個值是否為陣列。 IE9+、 Firefox 4+、Safari 5+、Opera 10.5+和Chrome都實作了這個方法。但是在IE8之前的版本是不支援的。 ############
function isArray(object){
  return object && typeof object==='object' &&  
      typeof object.length==='number' && 
      typeof object.splice==='function' &&  
       //判断length属性是否是可枚举的 对于数组 将得到false 
      !(object.propertyIsEnumerable('length'));
}
######4) Object.prototype.toString.call###############
Object.prototype.toString.call(value) == '[object Array]'

以上是如何判斷js資料型別與陣列的方法實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn