JavaScript中判斷數(shù)據(jù)類(lèi)型的方法總結(jié)
typeof
typeof用的比較多的時(shí)候,是判斷某個(gè)全局變量在不在,假如某個(gè)頁(yè)面定義了一個(gè)全局變量。假如你做如下判斷:
//haorooms是全局變量
if(haorooms!=undefined){
}//js會(huì)報(bào)錯(cuò),說(shuō)"Uncaught ReferenceError: haorooms is not defined"
解決的方法是我們?nèi)缦聦?xiě):
if(typeof haorooms!=undefined){
}
用了typeof之后,就不會(huì)報(bào)錯(cuò)了!這是typeof的應(yīng)用之一!
此外,typeof還可以進(jìn)行數(shù)據(jù)類(lèi)型的判斷!如下:
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ù)類(lèi)型還可以判斷function類(lèi)型
很明顯,對(duì)于typeof,除了前四個(gè)類(lèi)型外,null、對(duì)象、數(shù)組返回的都是object類(lèi)型;
instanceof
可以用其判斷是否是數(shù)組。
var haorooms=[]; console.log(haorooms instanceof Array) //返回true
constructor
constructor就是返回對(duì)象相對(duì)應(yīng)的構(gòu)造函數(shù)。
判斷各種數(shù)據(jù)類(lèi)型的方法:
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;}
通過(guò)輸出haorooms.constructor,可以看出constructor就是返回對(duì)象相對(duì)應(yīng)的構(gòu)造函數(shù)。
Object.prototype.toString
前面我們提到了可以運(yùn)用 constructor 屬性來(lái)判定物件類(lèi)型,讓我們?cè)賮?lái)講講 Object.protype.toString 這個(gè)方法
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]"
運(yùn)用這種方式我們可以正確的判斷一個(gè)變量的基本型態(tài),但是如果是自訂類(lèi)型的話(huà),卻無(wú)法得知真正的類(lèi)型,因?yàn)榻Y(jié)果依然會(huì)是 [object Object]
其他
jQuery 也有類(lèi)型判斷的方法,下面是一例
$.isWindow(window) // true
怎么做的呢
core.js#479
isWindow: function( obj ) {
return obj != null && obj == obj.window;
}
所以開(kāi)一個(gè)這樣的 Object:
var fakeWindow;
fakeWindow = {};
fakeWindow.window = fakeWindow;
$.isWindow(fakeWindow) // true
你就騙過(guò)他了。
小結(jié)
在 JavaScript 中要正確判斷類(lèi)型,當(dāng)仔細(xì)去鉆研的時(shí)候,真是一件麻煩事,根據(jù)不同的情境去設(shè)計(jì)你的判斷式是相當(dāng)重要的,我們也必須要去思考如何用最簡(jiǎn)潔的方式判斷正確的類(lèi)型,當(dāng)然這篇還有很多地方?jīng)]有介紹到,例如 isPrototypeOf 這個(gè)方法,JavaScript 是一個(gè)有許多歷史包袱的語(yǔ)言,但也是不斷的在進(jìn)步,運(yùn)用它的時(shí)候,要注意,有太多的方式是雙面刃,切記要小心運(yùn)用。
- js 判斷數(shù)據(jù)類(lèi)型的幾種方法
- js 判斷各種數(shù)據(jù)類(lèi)型的簡(jiǎn)單方法(推薦)
- Javascript如何判斷數(shù)據(jù)類(lèi)型和數(shù)組類(lèi)型
- js的各種數(shù)據(jù)類(lèi)型判斷的介紹
- 利用JS判斷數(shù)據(jù)類(lèi)型的四種方法
- JS中的四種數(shù)據(jù)類(lèi)型判斷方法
- JavaScript 判斷數(shù)據(jù)類(lèi)型的4種方法
- js和jquery判斷數(shù)據(jù)類(lèi)型的4種方法總結(jié)
- JS數(shù)據(jù)類(lèi)型判斷的幾種常用方法
- JS數(shù)據(jù)類(lèi)型判斷的9種方式總結(jié)
相關(guān)文章
Bootstrap中的fileinput 多圖片上傳及編輯功能
這篇文章主要介紹了Bootstrap中的fileinput 多圖片上傳及編輯功能的實(shí)現(xiàn),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
如何通過(guò)javaScript去除字符串兩端的空白字符
這篇文章主要介紹了如何通過(guò)javaScripte去除字符串兩端的空白字符,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02
Ionic項(xiàng)目中Native Camera的使用方法
Ionic項(xiàng)目中如何使用Native Camera?這篇文章主要介紹了Ionic項(xiàng)目中Native Camera的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
關(guān)于layui導(dǎo)航欄不展示下拉列表的解決方法
今天小編就為大家分享一篇關(guān)于layui導(dǎo)航欄不展示下拉列表的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
小程序?qū)崿F(xiàn)自定義導(dǎo)航欄適配完美版
這篇文章主要介紹了小程序?qū)崿F(xiàn)自定義導(dǎo)航欄適配完美版,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
JavaScript欄目列表隱藏/顯示簡(jiǎn)單實(shí)現(xiàn)
隱藏側(cè)邊欄,并將圖片換成右箭頭圖片;顯示側(cè)邊欄,并將圖片換成左箭頭,這樣的效果想必大家都很熟悉吧,接下來(lái)實(shí)現(xiàn)下,感興趣的朋友可以參考下哈2013-04-04
JavaScript 隱式類(lèi)型轉(zhuǎn)換規(guī)則詳解
這篇文章主要為大家介紹了JavaScript 隱式類(lèi)型轉(zhuǎn)換規(guī)則詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2023-05-05

