JavaScript中判斷數(shù)據(jù)類型的方法總結(jié)
來源:易賢網(wǎng) 閱讀:591 次 日期:2016-06-23 16:17:12
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript中判斷數(shù)據(jù)類型的方法總結(jié)”,方便廣大網(wǎng)友查閱!

比如要判斷一個變量是否是數(shù)組類型,PHP中有is_array()函數(shù)可以直接判斷,然而js中我們需要...-- well,下面我們就來詳細(xì)看一下JavaScript中判斷數(shù)據(jù)類型的方法總結(jié)

typeof

typeof用的比較多的時候,是判斷某個全局變量在不在,假如某個頁面定義了一個全局變量。假如你做如下判斷:

//haorooms是全局變量

if(haorooms!=undefined){

}//js會報錯,說"Uncaught ReferenceError: haorooms is not defined"

解決的方法是我們?nèi)缦聦懀?/P>

if(typeof haorooms!=undefined){

}

用了typeof之后,就不會報錯了!這是typeof的應(yīng)用之一!

此外,typeof還可以進(jìn)行數(shù)據(jù)類型的判斷!如下:

var haorooms="string"; console.log(haorooms); //string

var haorooms=1; console.log(haorooms); //number

var haorooms=false; console.log(haorooms); //boolean

var haorooms; console.log(typeof haorooms); //undfined

var haorooms= null; console.log(typeof haorooms); //object

var haorooms = document; console.log(typeof haorooms); //object

var haorooms = []; console.log(haorooms); //object

var haorooms = function(){}; console.log(typeof haorooms) //function  除了可以判斷數(shù)據(jù)類型還可以判斷function類型

很明顯,對于typeof,除了前四個類型外,null、對象、數(shù)組返回的都是object類型;

instanceof

可以用其判斷是否是數(shù)組。

var haorooms=[];

console.log(haorooms instanceof Array) //返回true 

constructor

constructor就是返回對象相對應(yīng)的構(gòu)造函數(shù)。

判斷各種數(shù)據(jù)類型的方法:

console.log([].constructor == Array);

console.log({}.constructor == Object);

console.log("string".constructor == String);

console.log((123).constructor == Number);

console.log(true.constructor == Boolean);

function employee(name,job,born){

  this.name=name;

  this.job=job;

  this.born=born; }

var haorooms=new employee("Bill Gates","Engineer",1985); 

console.log(haorooms.constructor); //輸出function employee(name, jobtitle, born){this.name = name; this.jobtitle = job; this.born = born;}

通過輸出haorooms.constructor,可以看出constructor就是返回對象相對應(yīng)的構(gòu)造函數(shù)。

Object.prototype.toString

前面我們提到了可以運用 constructor 屬性來判定物件類型,讓我們再來講講 Object.protype.toString 這個方法

Object.prototype.toString.apply({}) // "[object Object]"

Object.prototype.toString.apply([]) // "[object Array]"

Object.prototype.toString.apply(NaN)// "[object Number]"

Object.prototype.toString.apply(function(){}) // "[object Function]"

運用這種方式我們可以正確的判斷一個變量的基本型態(tài),但是如果是自訂類型的話,卻無法得知真正的類型,因為結(jié)果依然會是 [object Object]

其他

jQuery 也有類型判斷的方法,下面是一例

$.isWindow(window) // true

怎么做的呢

core.js#479

isWindow: function( obj ) {

  return obj != null && obj == obj.window;

}

所以開一個這樣的 Object:

var fakeWindow;

fakeWindow = {};

fakeWindow.window = fakeWindow;

$.isWindow(fakeWindow) // true

你就騙過他了。

小結(jié)

在 JavaScript 中要正確判斷類型,當(dāng)仔細(xì)去鉆研的時候,真是一件麻煩事,根據(jù)不同的情境去設(shè)計你的判斷式是相當(dāng)重要的,我們也必須要去思考如何用最簡潔的方式判斷正確的類型,當(dāng)然這篇還有很多地方?jīng)]有介紹到,例如 isPrototypeOf 這個方法,JavaScript 是一個有許多歷史包袱的語言,但也是不斷的在進(jìn)步,運用它的時候,要注意,有太多的方式是雙面刃,切記要小心運用。

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:JavaScript中判斷數(shù)據(jù)類型的方法總結(jié)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)