亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解JavaScript中的4種類型識別方法

 更新時間:2015年09月14日 11:06:50   作者:小火柴的藍色理想  
JavaScript中檢測對象類型的運算符有:typeof、instanceof,還有對象的constructor屬性: 1) typeof 運算符 typeof 是一元運算符,返回結(jié)果是一個說明運算數(shù)類型的字符串。下面由小編給大家分享JavaScript中的4種類型識別方法,需要的朋友可以參考下本文

具體內(nèi)容如下:

1.typeof

  【輸出】首字母小寫的字符串形式

  【功能】

    [a]可以識別標(biāo)準(zhǔn)類型(將Null識別為object)
    [b]不能識別具體的對象類型(Function除外)

  【實例】

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ù)類型]的字符串形式

  【功能】

    [a]可以識別標(biāo)準(zhǔn)類型及內(nèi)置對象類型
    [b]不能識別自定義類型

  【構(gòu)造方法】

function type(obj){
  return Object.prototype.toString.call(obj).slice(8,-1).toLowerCase();
}  

  【實例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]

  【實例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ù)類型(){[native code]}或者function 自定義類型(){}

  【功能】

    [a]可以識別標(biāo)準(zhǔn)類型、內(nèi)置對象類型及自定義類型
    [b]不能識別undefined、null,會報錯

  【構(gòu)造方法】

function type(obj){
  var temp = obj.constructor.toString();
  return temp.replace(/^function (\w+)\(\).+$/,'$1');
}

  【實例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);//報錯
//console.log((null).constructor);//報錯
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(){}

  【實例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));//錯誤
//console.log(type(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));//"person"

4.instanceof

  【輸出】true或false

  【功能】

    [a]可以識別內(nèi)置對象類型、自定義類型及其父類型
    [b]不能識別標(biāo)準(zhǔn)類型,會返回false
    [c]不能識別undefined、null,會報錯

  【實例】

console.log("jerry" instanceof String);//false
console.log(12 instanceof Number);//false
console.log(true instanceof Boolean);//false
//console.log(undefined instanceof Undefined);//報錯
//console.log(null instanceof Null);//報錯
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種類型識別方法,希望大家喜歡。

相關(guān)文章

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

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

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

    JavaScript寫的一個自定義彈出式對話框代碼

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

    js 進度條實現(xiàn)代碼

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

    JS+CSS實現(xiàn)隨機點名(實例代碼)

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

    JavaScript使用promise處理多重復(fù)請求

    處理重復(fù)請求的文章想必大家也看過了很多,大多數(shù)都是分為在response返回之前發(fā)現(xiàn)重復(fù)請求就return掉的和使用節(jié)流/防抖來間接規(guī)避用戶頻繁操作兩種版本的。本文主要介紹了JavaScript使用promise處理多重復(fù)請求,感興趣的可以了解一下
    2021-05-05
  • JavaScript 更嚴(yán)格的相等 [譯]

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

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

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

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

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

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

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

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

    關(guān)于javascript的一些知識以及循環(huán)詳解

    下面小編就為大家?guī)硪黄P(guān)于javascript的一些知識以及循環(huán)詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09

最新評論