JS數(shù)據(jù)類(lèi)型分類(lèi)及常用判斷方法
數(shù)據(jù)類(lèi)型判斷的方法
在探索數(shù)據(jù)類(lèi)型判斷方法的時(shí)候我們需要知道JS中有哪些數(shù)據(jù)類(lèi)型:
我們可以把JS中數(shù)據(jù)類(lèi)型分為兩類(lèi):
1.基本數(shù)據(jù)類(lèi)型:Undefined、Null、Boolean、Number、String、Symbol(es6中新增)
2.引用類(lèi)型(復(fù)雜數(shù)據(jù)類(lèi)型):里面包含 function、Array、Date 等
判斷數(shù)據(jù)類(lèi)型的方法有幾種
1.typeof
我相信typeof這個(gè)判斷數(shù)據(jù)類(lèi)型的方法是大家平常用的比較多的,閑話(huà)不多說(shuō),直接上代碼:
console.log(typeof 1);//numberconsole.log(typeof ’hello’);//stringconsole.log(typeof true);//booleanconsole.log(typeof null);//objectconsole.log(typeof Symbol(1));//symbolconsole.log(typeof undefined);//undefinedconsole.log(typeof function(){});//functionconsole.log(typeof []);//objectconsole.log(typeof {});//object
通過(guò)以上代碼和輸出我們大概可以看出,typeof這個(gè)判斷能判斷出大部分的數(shù)據(jù)類(lèi)型,但是基本類(lèi)型中有null的類(lèi)型被判斷為object
所以這個(gè)判斷還不是那么精確,我們需要其它判斷方法
2.instanceof 用于檢測(cè)構(gòu)造函數(shù)的 prototype 屬性是否出現(xiàn)在某個(gè)實(shí)例的原型鏈上
1.instanceof 左為實(shí)例,右為構(gòu)造函數(shù)。即判斷左是不是右的實(shí)例對(duì)象。內(nèi)部機(jī)制是通過(guò)原型鏈來(lái)判斷的
2.instanceof 可以精準(zhǔn)判斷引用數(shù)據(jù)類(lèi)型 Array,F(xiàn)unction,Object,而基本數(shù)據(jù)類(lèi)型不能被 instanceof 精準(zhǔn)判斷,因?yàn)樗旧聿皇且粋€(gè)實(shí)例對(duì)象
console.log(2 instanceof Number);//falseconsole.log(new Number(2) instanceof Number);//trueconsole.log(’str’ instanceof String); //falseconsole.log(new String(’str’) instanceof String); //trueconsole.log([] instanceof Array);//trueconsole.log([]instanceof Object);//trueconsole.log({} instanceof Object);//trueconsole.log({} instanceof Array);//falseconsole.log(function(){} instanceof Function); // true
在以上代碼中,我們可以看出這個(gè)判斷方法還是沒(méi)解決實(shí)際性的問(wèn)題,比如我們想判斷null為null,所以接下來(lái)介紹一個(gè)精確的判斷方法
3.Object.prototype.toString.call()
1.使用 Object 對(duì)象的原型方法 toString,使用 call 改變 this 指向
見(jiàn)代碼:
const a = Object.prototype.toString;console.log(a.call(2)); // [object Number]console.log(a.call(true)); // [object Boolean]console.log(a.call(’str’)); // [object String]console.log(a.call(Symbol())) // [object Symbol]console.log(a.call([])); // [object Array]console.log(a.call(function(){})); // [object Function]console.log(a.call({})); // [object Object]console.log(a.call(undefined)); // [object Undefined]console.log(a.call(null)); // [object Null]console.log(a.call(new Date())) // [object Date]console.log(a.call(new Error())) // [object Error]console.log(a.call(new RegExp())) // [object RegExp
見(jiàn)上面輸出可知,Object.prototype.toString.call()可以判斷出復(fù)雜類(lèi)型中的Array,F(xiàn)unction,Date等類(lèi)型,所以我們知道,當(dāng)我們需要判斷復(fù)雜類(lèi)型時(shí),或者判斷簡(jiǎn)單數(shù)據(jù)類(lèi)型中的null為null時(shí)我們可以用次方法,判斷簡(jiǎn)單類(lèi)型中的其他數(shù)據(jù)類(lèi)型我們可以用typeof來(lái)判斷就可以
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 詳解Android studio 動(dòng)態(tài)fragment的用法2. Android如何加載Base64編碼格式圖片3. 解決Android studio xml界面無(wú)法預(yù)覽問(wèn)題4. 圖文詳解vue中proto文件的函數(shù)調(diào)用5. 什么是python的自省6. Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁(yè)效果(實(shí)例代碼)7. Vuex localStorage的具體使用8. php模擬實(shí)現(xiàn)斗地主發(fā)牌9. vue 使用localstorage實(shí)現(xiàn)面包屑的操作10. Vue封裝一個(gè)TodoList的案例與瀏覽器本地緩存的應(yīng)用實(shí)現(xiàn)

網(wǎng)公網(wǎng)安備