詳解JavaScript中的4種類(lèi)型識(shí)別方法
具體內(nèi)容如下:
1.typeof
【輸出】首字母小寫(xiě)的字符串形式
【功能】
[a]可以識(shí)別標(biāo)準(zhǔn)類(lèi)型(將Null識(shí)別為object)
[b]不能識(shí)別具體的對(duì)象類(lèi)型(Function除外)
【實(shí)例】
console.log(typeof "jerry");//"string" console.log(typeof 12);//"number" console.log(typeof true);//"boolean" console.log(typeof undefined);//"undefined" console.log(typeof null);//"object" console.log(typeof {name: "jerry"});//"object" console.log(typeof function(){});//"function" console.log(typeof []);//"object" console.log(typeof new Date);//"object" console.log(typeof /\d/);//"object" function Person(){}; console.log(typeof new Person);//"object"
2.Object.prototype.toString
【輸出】[object 數(shù)據(jù)類(lèi)型]的字符串形式
【功能】
[a]可以識(shí)別標(biāo)準(zhǔn)類(lèi)型及內(nèi)置對(duì)象類(lèi)型
[b]不能識(shí)別自定義類(lèi)型
【構(gòu)造方法】
function type(obj){ return Object.prototype.toString.call(obj).slice(8,-1).toLowerCase(); }
【實(shí)例1】
console.log(Object.prototype.toString.call("jerry"));//[object String] console.log(Object.prototype.toString.call(12));//[object Number] console.log(Object.prototype.toString.call(true));//[object Boolean] console.log(Object.prototype.toString.call(undefined));//[object Undefined] console.log(Object.prototype.toString.call(null));//[object Null] console.log(Object.prototype.toString.call({name: "jerry"}));//[object Object] console.log(Object.prototype.toString.call(function(){}));//[object Function] console.log(Object.prototype.toString.call([]));//[object Array] console.log(Object.prototype.toString.call(new Date));//[object Date] console.log(Object.prototype.toString.call(/\d/));//[object RegExp] function Person(){}; console.log(Object.prototype.toString.call(new Person));//[object Object]
【實(shí)例2】
function type(obj){ return Object.prototype.toString.call(obj).slice(8,-1).toLowerCase(); } console.log(type("jerry"));//"string" console.log(type(12));//"number" console.log(type(true));//"boolean" console.log(type(undefined));//"undefined" console.log(type(null));//"null" console.log(type({name: "jerry"}));//"object" console.log(type(function(){}));//"function" console.log(type([]));//"array" console.log(type(new Date));//"date" console.log(type(/\d/));//"regexp" function Person(){}; console.log(type(new Person));//"object"
3.constructor
【輸出】function 數(shù)據(jù)類(lèi)型(){[native code]}或者function 自定義類(lèi)型(){}
【功能】
[a]可以識(shí)別標(biāo)準(zhǔn)類(lèi)型、內(nèi)置對(duì)象類(lèi)型及自定義類(lèi)型
[b]不能識(shí)別undefined、null,會(huì)報(bào)錯(cuò)
【構(gòu)造方法】
function type(obj){ var temp = obj.constructor.toString(); return temp.replace(/^function (\w+)\(\).+$/,'$1'); }
【實(shí)例1】
console.log(("jerry").constructor);//function String(){[native code]} console.log((12).constructor);//function Number(){[native code]} console.log((true).constructor);//function Boolean(){[native code]} //console.log((undefined).constructor);//報(bào)錯(cuò) //console.log((null).constructor);//報(bào)錯(cuò) console.log(({name: "jerry"}).constructor);//function Object(){[native code]} console.log((function(){}).constructor);//function Function(){[native code]} console.log(([]).constructor);//function Array(){[native code]} console.log((new Date).constructor);//function Date(){[native code]} console.log((/\d/).constructor);//function RegExp(){[native code]} function Person(){}; console.log((new Person).constructor);//function Person(){}
【實(shí)例2】
function type(obj){ var temp = obj.constructor.toString().toLowerCase(); return temp.replace(/^function (\w+)\(\).+$/,'$1'); } console.log(type("jerry"));//"string" console.log(type(12));//"number" console.log(type(true));//"boolean" //console.log(type(undefined));//錯(cuò)誤 //console.log(type(null));//錯(cuò)誤 console.log(type({name: "jerry"}));//"object" console.log(type(function(){}));//"function" console.log(type([]));//"array" console.log(type(new Date));//"date" console.log(type(/\d/));//"regexp" function Person(){}; console.log(type(new Person));//"person"
4.instanceof
【輸出】true或false
【功能】
[a]可以識(shí)別內(nèi)置對(duì)象類(lèi)型、自定義類(lèi)型及其父類(lèi)型
[b]不能識(shí)別標(biāo)準(zhǔn)類(lèi)型,會(huì)返回false
[c]不能識(shí)別undefined、null,會(huì)報(bào)錯(cuò)
【實(shí)例】
console.log("jerry" instanceof String);//false console.log(12 instanceof Number);//false console.log(true instanceof Boolean);//false //console.log(undefined instanceof Undefined);//報(bào)錯(cuò) //console.log(null instanceof Null);//報(bào)錯(cuò) console.log({name: "jerry"} instanceof Object);//true console.log(function(){} instanceof Function);//true console.log([] instanceof Array);//true console.log(new Date instanceof Date);//true console.log(/\d/ instanceof RegExp);//true function Person(){}; console.log(new Person instanceof Person);//true console.log(new Person instanceof Object);//true
以上內(nèi)容就是詳解JavaScript中的4種類(lèi)型識(shí)別方法,希望大家喜歡。
相關(guān)文章
JavaScript寫(xiě)的一個(gè)自定義彈出式對(duì)話框代碼
最近閑來(lái)無(wú)事,用js自己做了一個(gè)彈出式對(duì)話框,需要應(yīng)用彈出式對(duì)話框的朋友可以參考下。2010-01-01JS+CSS實(shí)現(xiàn)隨機(jī)點(diǎn)名(實(shí)例代碼)
本文通過(guò)js html和cass代碼實(shí)現(xiàn)了隨機(jī)點(diǎn)名效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-11-11JavaScript使用promise處理多重復(fù)請(qǐng)求
處理重復(fù)請(qǐng)求的文章想必大家也看過(guò)了很多,大多數(shù)都是分為在response返回之前發(fā)現(xiàn)重復(fù)請(qǐng)求就return掉的和使用節(jié)流/防抖來(lái)間接規(guī)避用戶頻繁操作兩種版本的。本文主要介紹了JavaScript使用promise處理多重復(fù)請(qǐng)求,感興趣的可以了解一下2021-05-05JavaScript中常用的數(shù)組過(guò)濾方法例子
這篇文章主要給大家介紹了關(guān)于JavaScript中常用的數(shù)組過(guò)濾方法的相關(guān)資料,數(shù)組過(guò)濾器方法是JavaScript中使用最廣泛的方法之一,它允許我們快速過(guò)濾出具有特定條件的數(shù)組中的元素,需要的朋友可以參考下2023-11-11layui給下拉框、按鈕狀態(tài)、時(shí)間賦初始值的方法
今天小編就為大家分享一篇layui給下拉框、按鈕狀態(tài)、時(shí)間賦初始值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09關(guān)于javascript的一些知識(shí)以及循環(huán)詳解
下面小編就為大家?guī)?lái)一篇關(guān)于javascript的一些知識(shí)以及循環(huán)詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09