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

JS疑惑的數(shù)據(jù)類型及類型判斷方法詳解

 更新時(shí)間:2022年08月16日 15:37:42   作者:寒月十九  
這篇文章主要為大家介紹了JS中疑惑的數(shù)據(jù)類型及類型判斷方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

關(guān)于javascript這門語言的數(shù)據(jù)類型你了解多少呢?你有什么方法能夠快速的判斷數(shù)據(jù)類型呢?如果可以那如何實(shí)現(xiàn)類型轉(zhuǎn)換呢?帶著這三個(gè)問題開始我們今天的學(xué)習(xí)吧

數(shù)據(jù)類型

在javascript中數(shù)據(jù)類型我們一般分為基本數(shù)據(jù)類型(值類型) 和 引用數(shù)據(jù)類型(對(duì)象類型);

基本數(shù)據(jù)類型有:

  • number
  • String
  • boolean
  • Null
  • Undefined
  • BigInt
  • Symbol

引用數(shù)據(jù)類型有:

  • Object(對(duì)象)
  • Array(數(shù)組)
  • Function(函數(shù))
  • Date等(內(nèi)置對(duì)象)

類型判斷

一、typeof方法

typeof 123 // "number" 
typeof 'a'  // "string"
typeof true  // "boolean"
typeof undefined // "undefined"
typeof Symbol() // "symbol"
typeof 21n // "bigint"

通過以上這些例子我們可以總結(jié)出一個(gè)規(guī)律: typeof方法可以準(zhǔn)確判斷出除了Null之外的所有的基本數(shù)據(jù)類型(注:typeof null // "object" 是javascript這門語言的歷史遺留問題,需要記憶),其他六種基本數(shù)據(jù)類型都能準(zhǔn)確判斷,所以我們可以用(typeof 變量 === “undefined”)來判斷一個(gè)變量是否被聲明;但是在判斷引用類型時(shí)typeof智能判斷出函數(shù)類型,其他的引用類型都返回'object'。 所以我們通常會(huì)使用typeof方法來判斷基本數(shù)據(jù)類型。

二、Object.prototype.toString.call()方法

Object.prototype.toString.call()方法,它的返回值是"[ object , 類型]"(注:返回值前面是小寫字母,后面是大寫字母開頭的類型)

Object.prototype.toString.call(123) // "[object Number]"
Object.prototype.toString.call('abc') // "[object String]"
Object.prototype.toString.call(Symbol()) // "[object Symbol]"
Object.prototype.toString.call(21n) // "[object BigInt]"
Object.prototype.toString.call(null) // "[object Null]"
Object.prototype.toString.call(undefined) // "[object Undefined]"
Object.prototype.toString.call(true) // "[object Boolean]

由此可見Object.prototype.toString.call()方法可以準(zhǔn)確判斷所有的基本數(shù)據(jù)類型,那么對(duì)引用數(shù)據(jù)類型呢?

Object.prototype.toString.call({a:1}) // "[object Object]"
Object.prototype.toString.call([1,2]) // "[object Array]"
Object.prototype.toString.call(new Date) // "[object Date]"
Object.prototype.toString.call(function(){}) // "[object Function]"
Object.prototype.toString.call(new Error()) // "[object Error]"
Object.prototype.toString.call(/a/g) // "[object RegExp]"--正則表達(dá)式
Object.prototype.toString.call(Math) // "[object Math]"
Object.prototype.toString.call(JSON) // "[object JSON]"

所以O(shè)bject.prototype.toString.call()方法可以識(shí)別出javascript這門語言中所有的數(shù)據(jù)類型(據(jù)我所知,上述例子中Math屬性和正則嚴(yán)格意義上也不算數(shù)據(jù)類型,因?yàn)榭梢宰R(shí)別出,所以也放在例子里)。

小插曲

如何使用上述的兩種方法優(yōu)雅的封裝一個(gè)方法,使得我們可以傳入任意數(shù)據(jù),直接返回它的數(shù)據(jù)類型(小寫字母的字符串)?

方法一:

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

方法二:

let dataType = {}
['Boolean', 'Number', 'String', 'Array', 'Function', 'Date', 'RegExp', 'Object',
'Error', 'Undefined', 'Null'].map((item, index) => {
    dataType["[object" + item + "]"] = item.toLowerCase();
})
function type(obj) {
    return typeof obj === 'object' || typeof obj === 'function'
        ? dataTypeObject.prototype.toString.call(obj)] 
        || 'object' : typeof obj
}

我們一起來解讀一下方法二,首先我們先將數(shù)據(jù)類型的首字母都轉(zhuǎn)化為小寫字母,并在添加為我們創(chuàng)建的dataType對(duì)象的屬性(toLowerCase() 方法將字符串轉(zhuǎn)換為小寫。)

當(dāng)我們傳入一個(gè)數(shù)據(jù)時(shí),首先用typeof去判斷是基本數(shù)據(jù)類型還是引用數(shù)據(jù)類型,因?yàn)閠ypeof null // "object",所以我們的判定條件typeof obj === 'object' || typeof obj === 'function',就把特殊的null當(dāng)做引用類型,使用Object.prototype.toString.call()方法也能識(shí)別出,實(shí)現(xiàn)我們想要的效果。

(在學(xué)習(xí)過程中我們盡可能多去復(fù)雜化問題,使得理解更加深刻,方法一實(shí)用性較大)

三、Array.isArray()

在數(shù)組身上有一種isArray方法可以判斷是否為數(shù)組類型數(shù)據(jù),返回值是布爾類型(true || false)(在其他語言中arr2 = [1, 'abc', true]嚴(yán)格意義上不算數(shù)組,但是在javascript中屬于數(shù)組 )

四、obj instanceof Object

左邊放你要判斷的內(nèi)容,右邊放類型來進(jìn)行JS類型判斷,只能用來判斷復(fù)雜數(shù)據(jù)類型,因?yàn)閕nstanceof 是用于檢測(cè)構(gòu)造函數(shù)(右邊)的 prototype 屬性是否出現(xiàn)在某個(gè)實(shí)例對(duì)象(左邊)的原型鏈上。

[1,2] instanceof Array  // true
(function(){}) instanceof Function // true
({a:1}) instanceof Object // true
(new Date) instanceof Date // true
實(shí)現(xiàn)原理:
function instance_of(L,R){
    let O = R.prototype
    let L = L.__proto__
    while(L !== null){
        if(L === O) return true
        L = L.__proto__
    }
    return false
}
obj instanceof Object方法也可以判斷內(nèi)置對(duì)象。

結(jié)語

以上就是本期的所有內(nèi)容,相信此時(shí),判斷javascript中的數(shù)據(jù)類型已經(jīng)沒有什么可以難倒你了,當(dāng)然判斷數(shù)據(jù)類型的方法不僅這些,但是以上的幾種方法(應(yīng)該)可以解決所有的數(shù)據(jù)類型判斷的問題。

以上就是JS疑惑的數(shù)據(jù)類型及類型判斷方法詳解的詳細(xì)內(nèi)容,更多關(guān)于JS數(shù)據(jù)類型判斷的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 淺談JS正則RegExp對(duì)象

    淺談JS正則RegExp對(duì)象

    這篇文章主要介紹JS正則RegExp對(duì)象,正則表達(dá)式是描述字符模式的對(duì)象,用于對(duì)字符串模式匹配及檢索替換,是對(duì)字符串執(zhí)行模式匹配的強(qiáng)大工具。下面就來看具體詳情,需要的朋友可以參考一下
    2021-10-10
  • 微信小程序 頁面?zhèn)鲄?shí)例詳解

    微信小程序 頁面?zhèn)鲄?shí)例詳解

    這篇文章主要介紹了微信小程序 頁面?zhèn)鲄?shí)例詳解的相關(guān)資料,這里對(duì)頁面跳轉(zhuǎn)及傳遞參數(shù)的功能做個(gè)小示例,幫助大家盡快上手,很簡單,需要的朋友可以參考下
    2016-11-11
  • 微信小程序 MINA文件結(jié)構(gòu)

    微信小程序 MINA文件結(jié)構(gòu)

    這篇文章主要介紹了微信小程序 MINA文件結(jié)構(gòu)的相關(guān)資料,這里詳細(xì)介紹了微信小程序的文件目錄及文件作用,需要的朋友可以參考下
    2016-10-10
  • 項(xiàng)目中常用的 .env 文件原理源碼解析

    項(xiàng)目中常用的 .env 文件原理源碼解析

    這篇文章主要為大家介紹了項(xiàng)目中常用的 .env 文件原理源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 微信小程序 數(shù)據(jù)訪問實(shí)例詳解

    微信小程序 數(shù)據(jù)訪問實(shí)例詳解

    這篇文章主要介紹了微信小程序 數(shù)據(jù)訪問實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • JS創(chuàng)建對(duì)象的四種方式

    JS創(chuàng)建對(duì)象的四種方式

    這篇文章主要給大家分享JS創(chuàng)建對(duì)象的四種方式,分別是字面量的方式去創(chuàng)建對(duì)象、使用new字符創(chuàng)建對(duì)象、自定義構(gòu)造函數(shù)、工廠模式創(chuàng)建對(duì)象,更多詳細(xì)內(nèi)容,請(qǐng)參考下面文章的具體內(nèi)容
    2021-11-11
  • 使用javascript解析二維碼的三種方式

    使用javascript解析二維碼的三種方式

    這篇文章主要給大家分享使用javascript解析二維碼的三種方式,二維碼就是將我們能看懂的文字語言,以機(jī)器語言的形式存儲(chǔ)了起來。其中黑色小方塊代表的是1,白色小方塊代表的是0,黑白相間的圖案其實(shí)就是一串編碼,掃碼的過程就是翻譯這些編碼的過程,需要的朋友可以參考一下
    2021-11-11
  • 沒有resolve及reject的Promise是否會(huì)造成內(nèi)存泄露

    沒有resolve及reject的Promise是否會(huì)造成內(nèi)存泄露

    這篇文章主要為大家介紹了一直沒有resolve及reject的Promise是否會(huì)造成內(nèi)存泄露的問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 瀏覽器切換到其他標(biāo)簽頁或最小化js定時(shí)器是否準(zhǔn)時(shí)測(cè)試

    瀏覽器切換到其他標(biāo)簽頁或最小化js定時(shí)器是否準(zhǔn)時(shí)測(cè)試

    這篇文章主要為大家介紹了瀏覽器切換到其他標(biāo)簽頁或最小化是js定時(shí)器是否準(zhǔn)時(shí)的測(cè)試詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • JavaScript異步操作中串行和并行

    JavaScript異步操作中串行和并行

    這篇文章主要介紹了JavaScript異步操作中串行和并行,主要內(nèi)容是寫一下js中es5和es6針對(duì)異步函數(shù),串行執(zhí)行和并行執(zhí)行的方案。已經(jīng)串行和并行結(jié)合使用的例子。,需要的朋友可以參考一下
    2021-11-11

最新評(píng)論