溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JavaScript判斷數(shù)據(jù)類型的方法

發(fā)布時(shí)間:2020-05-13 15:45:25 來(lái)源:億速云 閱讀:152 作者:Leah 欄目:web開(kāi)發(fā)

這篇文章主要為大家詳細(xì)介紹了JavaScript判斷數(shù)據(jù)類型的方法,代碼比較詳細(xì)全面,非常適合初學(xué)者入門(mén),感興趣的小伙伴們可以參考一下。

1、 常用的typeof

對(duì)于array、object、null的判斷是不友好的,可以看下圖的執(zhí)行結(jié)果。

JavaScript判斷數(shù)據(jù)類型的方法

var obj = {
  number:123,
  string: '123',
  bool: true,
  obj: {},
  arr: [],
  n: null,
  undef: undefined,
  fn: function () {}
}

for(key in obj) {
  console.log(key + ": " + typeof obj[key])
}

2. instanceof

instanceof測(cè)試構(gòu)造函數(shù)的prototype屬性是否出現(xiàn)在對(duì)象的原型鏈中的任何位置。
如果你了解原型鏈,你會(huì)知道原型鏈的復(fù)雜性,instanceof得到的值并不是固定不變的,它會(huì)沿著原型鏈查找,最明顯的是所有的基本數(shù)據(jù)類型都繼承與Object.protype.

[任何數(shù)據(jù)類型] instanceof Object
> true

如下圖:

JavaScript判斷數(shù)據(jù)類型的方法

3.最終方案:Object.prototype.toString.call()

下面是兼容性方案最好、最全面、也是最有效的:
下面有兩種實(shí)現(xiàn)方式(原型方法和全局方法),可以根據(jù)自己的需要選擇。

(function () {
  function isType(type,data) {
    // data是全局方法時(shí)使用的,原型方法可不填
    return Object.prototype.toString.call(data || this) === '[object ' + type + ']'
  }
  // 全局方法支持null和undefined
  // window.isType = isType

  // 添加到數(shù)據(jù)類型的原型中,不支持null和undefined
    Object.defineProperty(Object.prototype,'isType',{
      value:isType,
      writable:true,
        enumerable:false,
        configurable:true
    });
})()

使用方式:

var str = 'abc';
// 全局方法
isType('String', str) // True

// 原型方法
str.isType('String')

測(cè)試代碼:

var obj = {
  test: {
    number:123,
    string: '123',
    obj: {},
    bool: true,
    arr: [],
    n: null,
    undef: undefined,
    fn: function () {

    }
  }
}
// 原型方法不支持null和undefined,請(qǐng)用“===”
console.log(obj.test.number.isType('Number'))
console.log(obj.test.number.isType('String'))

console.log(obj.test.string.isType('String'))
console.log(obj.test.string.isType('Number'))

console.log(obj.test.obj.isType('Object'))
console.log(obj.test.obj.isType('Array'))

console.log(obj.test.arr.isType('Array'))
console.log(obj.test.arr.isType('Object'))


console.log(obj.test.fn.isType('Function'))
console.log(obj.test.fn.isType('Object'))

JavaScript判斷數(shù)據(jù)類型的方法

以上就是JavaScript判斷數(shù)據(jù)類型的方法,代碼示例簡(jiǎn)單明了,如果在日常工作遇到此問(wèn)題。通過(guò)這篇文章,希望你能有所收獲,更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI