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

JavaScript中檢測數(shù)據(jù)類型的四種方法

 更新時間:2022年01月09日 08:59:04   作者:不知名前端李小白  
這篇文章主要給大家分享的是JavaScript中檢測數(shù)據(jù)類型的四種方法,有 typeof、instanceof、constructor、Object.prototype.toString.call(),下面文章詳細介紹內(nèi)容,需要的小伙伴可以參考一下

前言:
在介紹檢測數(shù)據(jù)類型的方法之前,先說說JavaScript中數(shù)據(jù)類型有哪些吧~

JS數(shù)據(jù)類型主要分為兩大類:基本數(shù)據(jù)類型和引用數(shù)據(jù)類型

基本數(shù)據(jù)類型:number、string、boolean、null、undefined、symbol(es6)
引用數(shù)據(jù)類型:object(array、function、date...)

數(shù)據(jù)類型詳細介紹請點擊這里

檢測數(shù)據(jù)類型四種方法:

  • typeof
  • instanceof
  • constructor
  • Object.prototype.toString.call()

1. typeof

語法:

typeof(變量)
//or
typeof 變量

示例:

 

console.log(typeof ""); ? ? ? ? ? ?//string
console.log(typeof 1); ? ? ? ? ? ? //number
console.log(typeof true); ? ? ? ? ?//boolean
console.log(typeof null); ? ? ? ? ?//object!!!
console.log(typeof undefined); ? ? //undefined
console.log(typeof []); ? ? ? ? ? ?//object
console.log(typeof function(){}); ?//function
console.log(typeof console.log); ? //function
console.log(typeof {}); ? ? ? ? ? ?//object
console.log(typeof Symbol()); ? ? ?//symbol(es6)
console.log(typeof 23423n); ? ? ? ?//bigint(谷歌67版本新提出)

總結:

  • typeof 的返回類型為字符串,值有:number、boolean、string、object、functionundefined、symbol、bigint
  • typeof 一般用來判斷基本數(shù)據(jù)類型,除了判斷null會輸出"object",其它都是正確的
  • typeof 判斷引用數(shù)據(jù)類型時,除了判斷函數(shù)會輸出"function",其它都是輸出"object"

注意:這里涉及兩個經(jīng)常考的面試題!

  •  null 的數(shù)據(jù)類型是object (null是一個空的引用對象,是一個占位符)
  •  console.log 的數(shù)據(jù)類型是function 
  •  對于引用數(shù)據(jù)類型的判斷,使用typeof并不準確,所以可以使用instanceof來判斷引用數(shù)據(jù)類型

2. instanceof

instanceof 可以準確的判斷引用數(shù)據(jù)類型,它的原理是檢測構造函數(shù)的prototype屬性是否在某個實例對象的原型鏈上

語法:

obj1 instanceof obj2 //obj1 是否是 obj2的實例

示例:

 

console.log(9 instanceof Number); ? ? ? ? ? ? ? ? ? ?// false
console.log(true instanceof Boolean); ? ? ? ? ? ? ? ?// false?
console.log('libo' instanceof String); ? ? ? ? ? ? ? // false ?
console.log([] instanceof Array); ? ? ? ? ? ? ? ? ? ?// true
console.log(function(){} instanceof Function); ? ? ? // true
console.log({} instanceof Object); ? ? ? ? ? ? ? ? ? // true
// 注意以下兩組
console.log(typeof null); ? ? ? ? ? ? ? ? ? ? ? ? ? ?//object
console.log(null instanceof Object); ? ? ? ? ? ? ? ? //false !!!
console.log(typeof NaN); ? ? ? ? ? ? ? ? ? ? ? ? ? ? //number
console.log(NaN instanceof Number); ? ? ? ? ? ? ? ? ?//false !!!

總結:

  • instanceof 用來判斷對象,代碼形式為 【obj1 instanceof obj2】(obj2 必須為對象,否則會報錯?。?/li>
  • instanceof 返回值為布爾值

注意:

instanceof只能用來判斷兩個對象是否屬于實例關系, 而不能判斷一個對象實例具體屬于哪種類型

3. constructor(構造函數(shù))

當一個函數(shù) F被定義時,JS引擎會為F添加 prototype 原型,然后再在 prototype上添加一個 constructor 屬性,并讓其指向 F 的引用。

如下所示:

當執(zhí)行 var f = new F() 時,F(xiàn) 被當成了構造函數(shù),f 是F的實例對象,此時 F 原型上的 constructor 傳遞到了 f 上,因此f.constructor === F

可以看出,F(xiàn) 利用原型對象上的 constructor 引用了自身,當 F 作為構造函數(shù)來創(chuàng)建對象時,原型上的 constructor 就被遺傳到了新創(chuàng)建的對象上, 從原型鏈角度講,構造函數(shù) F 就是新對象的類型。這樣做的意義是,讓新對象在誕生以后,就具有可追溯的數(shù)據(jù)類型。

同樣,JavaScript 中的內(nèi)置對象在內(nèi)部構建時也是這樣做的:

 ??注意:

  • null和undefined是無效的對象,所以他們不會有constructor屬性!
  • 函數(shù)的constructor是不穩(wěn)定的,主要是因為開發(fā)者可以重寫prototype,原有的constructor引用會丟失,constructor會默認為Object

為什么變成了 Object?

因為 prototype 被重新賦值的是一個 { }, { } 是 new Object() 的字面量,因此 new Object() 會將 Object 原型上的 constructor 傳遞給 { },也就是 Object 本身。

因此,為了規(guī)范開發(fā),在重寫對象原型時一般都需要重新給 constructor 賦值,以保證對象實例的類型不被篡改。

4. Object.prototype.toString.call()

toString() 是 Object 的原型方法,調用該方法,默認返回當前對象的 [[Class]] 。這是一個內(nèi)部屬性,其格式為 [object Xxx] ,其中 Xxx 就是對象的類型。

對于 Object 對象,直接調用toString()  就能返回 [object Object] 。而對于其他對象,則需要通過 call / apply 來調用才能返回正確的類型信息。

 

Object.prototype.toString.call('') ; ? ? ? ? ? ? ?// [object String]
Object.prototype.toString.call(1) ; ? ? ? ? ? ? ? // [object Number]
Object.prototype.toString.call(true) ; ? ? ? ? ? ?// [object Boolean]
Object.prototype.toString.call(Symbol()); ? ? ? ? // [object Symbol]
Object.prototype.toString.call(undefined) ; ? ? ? // [object Undefined]
Object.prototype.toString.call(null) ; ? ? ? ? ? ?// [object Null]
Object.prototype.toString.call(new Function()) ; ?// [object Function]
Object.prototype.toString.call(new Date()) ; ? ? ?// [object Date]
Object.prototype.toString.call([]) ; ? ? ? ? ? ? ?// [object Array]
Object.prototype.toString.call(new RegExp()) ; ? ?// [object RegExp]
Object.prototype.toString.call(new Error()) ; ? ? // [object Error]
Object.prototype.toString.call(document) ; ? ? ? ?// [object HTMLDocument]
Object.prototype.toString.call(window) ; ? ? ? ? ?// [object global] window 是全局對象 global 的引用

到此這篇關于JavaScript中檢測數(shù)據(jù)類型的四種方法的文章就介紹到這了,更多相關JavaScript檢測數(shù)據(jù)類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • js如何對元素可視區(qū)域進行判定

    js如何對元素可視區(qū)域進行判定

    在前端開發(fā)中,有時候我們需要判斷一個元素是否在可視區(qū)域內(nèi),本文主要介紹了js如何對元素可視區(qū)域進行判定,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • 微信小程序開發(fā)animation心跳動畫效果

    微信小程序開發(fā)animation心跳動畫效果

    這篇文章主要為大家詳細介紹了微信小程序開發(fā)animation心跳動畫效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • JavaScript中變量提升和函數(shù)提升實例詳解

    JavaScript中變量提升和函數(shù)提升實例詳解

    這篇文章主要給大家介紹了關于JavaScript中變量提升和函數(shù)提升的相關資料,以及JS變量提升和函數(shù)提升的順序,文中給出了詳細的介紹,需要的朋友可以參考下
    2021-07-07
  • javascript圖片延遲加載實現(xiàn)方法及思路

    javascript圖片延遲加載實現(xiàn)方法及思路

    這篇文章主要介紹了javascript圖片延遲加載實現(xiàn)方法及思路,有時我們需要用懶加載,也就是延遲加載圖片的方式,來提高網(wǎng)站的親和力,需要的朋友可以參考下
    2015-12-12
  • js 定時器setTimeout無法調用局部變量的解決辦法

    js 定時器setTimeout無法調用局部變量的解決辦法

    javascript中定時器setTimeout無法調用局部變量,只需要將setTimeout的第一個參數(shù)改成函數(shù)對象,而不是字符串,就可以了
    2013-11-11
  • webpack中多文件打包配置的詳細流程

    webpack中多文件打包配置的詳細流程

    這篇文章主要介紹了webpack中多文件打包配置的詳細流程,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • JavaScript判斷兩個值相等的方法詳解

    JavaScript判斷兩個值相等的方法詳解

    在?JavaScript?中如何判斷兩個值相等,這個問題看起來非常簡單,但并非如此,在?JavaScript?中存在?4?種不同的相等邏輯,如果你不知道他們的區(qū)別,或者認為判斷相等非常簡單,本文就來為大家詳細講講
    2022-07-07
  • 基于js中的原型(全面講解)

    基于js中的原型(全面講解)

    下面小編就為大家?guī)硪黄趈s中的原型(全面講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 對js eval()函數(shù)的一些見解

    對js eval()函數(shù)的一些見解

    下面小編就為大家?guī)硪黄獙s eval()函數(shù)的一些見解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • JS實現(xiàn)touch 點擊滑動輪播實例代碼

    JS實現(xiàn)touch 點擊滑動輪播實例代碼

    這篇文章主要介紹了JS實現(xiàn)touch 點擊滑動輪播實例代碼,需要的朋友可以參考下
    2017-01-01

最新評論