欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解JavaScript中的4種類(lèi)型識(shí)別方法

 更新時(shí)間:2015年09月14日 11:06:50   作者:小火柴的藍(lán)色理想  
JavaScript中檢測(cè)對(duì)象類(lèi)型的運(yùn)算符有:typeof、instanceof,還有對(duì)象的constructor屬性: 1) typeof 運(yùn)算符 typeof 是一元運(yùn)算符,返回結(jié)果是一個(gè)說(shuō)明運(yùn)算數(shù)類(lèi)型的字符串。下面由小編給大家分享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)文章

  • 詳解CocosCreator消息分發(fā)機(jī)制

    詳解CocosCreator消息分發(fā)機(jī)制

    這篇文章主要介紹了詳解CocosCreator消息分發(fā)機(jī)制,詳細(xì)介紹了各模塊的設(shè)計(jì),同學(xué)們一定要自己看下
    2021-04-04
  • JavaScript寫(xiě)的一個(gè)自定義彈出式對(duì)話框代碼

    JavaScript寫(xiě)的一個(gè)自定義彈出式對(duì)話框代碼

    最近閑來(lái)無(wú)事,用js自己做了一個(gè)彈出式對(duì)話框,需要應(yīng)用彈出式對(duì)話框的朋友可以參考下。
    2010-01-01
  • js 進(jìn)度條實(shí)現(xiàn)代碼

    js 進(jìn)度條實(shí)現(xiàn)代碼

    非常簡(jiǎn)潔的進(jìn)度條實(shí)現(xiàn)代碼,一般用于一些比較耗時(shí)間的操作。
    2009-05-05
  • JS+CSS實(shí)現(xiàn)隨機(jī)點(diǎn)名(實(shí)例代碼)

    JS+CSS實(shí)現(xiàn)隨機(jī)點(diǎn)名(實(shí)例代碼)

    本文通過(guò)js html和cass代碼實(shí)現(xiàn)了隨機(jī)點(diǎn)名效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2019-11-11
  • JavaScript使用promise處理多重復(fù)請(qǐng)求

    JavaScript使用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-05
  • JavaScript 更嚴(yán)格的相等 [譯]

    JavaScript 更嚴(yán)格的相等 [譯]

    大部分JavaScript程序員都知道:應(yīng)該使用嚴(yán)格相等(===)來(lái)代替“普通”的相等操作(==).但是,有時(shí)候你的確需要一個(gè)比嚴(yán)格相等===更嚴(yán)格的運(yùn)算符,比如說(shuō):在你想檢查某個(gè)值是否是NaN的時(shí)候,又或者你想?yún)^(qū)分-0和+0的時(shí)候.本文解釋了相關(guān)的知識(shí)以及ECMAScript.next中的解決辦法:“is”操作符
    2012-09-09
  • javascript入門(mén)基礎(chǔ)之私有變量

    javascript入門(mén)基礎(chǔ)之私有變量

    開(kāi)始接觸這門(mén)語(yǔ)言時(shí),可能都會(huì)覺(jué)得這門(mén)語(yǔ)言缺少訪問(wèn)控制符(如public、private、protected),從而導(dǎo)致不能定義私有變量和私有方法。但經(jīng)過(guò)進(jìn)一步了解就會(huì)知道javascript同樣可以有私有變量。
    2010-02-02
  • JavaScript中常用的數(shù)組過(guò)濾方法例子

    JavaScript中常用的數(shù)組過(guò)濾方法例子

    這篇文章主要給大家介紹了關(guān)于JavaScript中常用的數(shù)組過(guò)濾方法的相關(guān)資料,數(shù)組過(guò)濾器方法是JavaScript中使用最廣泛的方法之一,它允許我們快速過(guò)濾出具有特定條件的數(shù)組中的元素,需要的朋友可以參考下
    2023-11-11
  • layui給下拉框、按鈕狀態(tài)、時(shí)間賦初始值的方法

    layui給下拉框、按鈕狀態(tài)、時(shí)間賦初始值的方法

    今天小編就為大家分享一篇layui給下拉框、按鈕狀態(tài)、時(shí)間賦初始值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • 關(guān)于javascript的一些知識(shí)以及循環(huán)詳解

    關(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

最新評(píng)論