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

JavaScript中如何判斷一個值的類型

 更新時間:2017年09月15日 09:20:17   投稿:mrr  
在js中有一個運算符可以幫助我們判斷一個值的類型,它就是typeof運算符。下面通過本文給大家分享JavaScript中如何判斷一個值的類型,需要的朋友參考下吧

我們知道在js中有一個運算符可以幫助我們判斷一個值的類型,它就是typeof運算符。

console.log(typeof 123);  //number
console.log(typeof '123'); //string
console.log(typeof true);  //boolean
console.log(typeof undefined); //undefined
console.log(typeof null); //object
console.log(typeof []);  //object
console.log(typeof {}); //object
console.log(typeof function() {}); //function

我們從以上結果可以看出typeof的不足之處,它對于數(shù)值、字符串、布爾值分別返回number、string、boolean,函數(shù)返回function,undefined返回undefined,除此以外,其他情況都返回object。

所以如果返回值為object,我們是無法得知值的類型到底是數(shù)組還是對象或者其他值。為了準確得到每個值的類型,我們必須使用js中另一個運算符instanceof。下面簡單的說一下instanceof的用法。

instanceof運算符返回一個布爾值,表示指定對象是否為某個構造函數(shù)的實例。

instanceof運算符的左邊是實例對象,右邊是構造函數(shù)。它會檢查右邊構造函數(shù)的ptototype屬性,是否在左邊對象的原型鏈上。

var b = [];
b instanceof Array //true
b instanceof Object //true

注意,instanceof運算符只能用于對象,不適用原始類型的值。

所以我們可以結合typeof和instanceof運算符的特性,來對一個值的類型做出較為準確的判斷。

//得到一個值的類型
function getValueType(value) {
  var type = '';
  if (typeof value != 'object') {
    type = typeof value;
  } else {
    if (value instanceof Array) {
      type = 'array';
    } else {
      if (value instanceof Object) {
        type = 'object';
      } else {
        type = 'null';
      }
    }
  }
  return type;
}
getValueType(123);  //number
getValueType('123'); //string
getValueType(true);  //boolean
getValueType(undefined); //undefined
getValueType(null); //null
getValueType([]);   //array
getValueType({});  //object
getValueType(function(){}); //function

總結

以上所述是小編給大家介紹的JavaScript中如何判斷一個值的類型,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • 普通web整合quartz跑定時任務的示例

    普通web整合quartz跑定時任務的示例

    這篇文章主要介紹了普通web整合quartz跑定時任務,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • javascript漢字拼音互轉的簡單實例

    javascript漢字拼音互轉的簡單實例

    下面小編就為大家?guī)硪黄猨avascript漢字拼音互轉的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • 淺析Promise的介紹及基本用法

    淺析Promise的介紹及基本用法

    Promise是異步編程的一種解決方案,在ES6中Promise被列為了正式規(guī)范,統(tǒng)一了用法,原生提供了Promise對象。接下來通過本文給大家介紹Promise的介紹及基本用法,感興趣的朋友一起看看吧
    2021-10-10
  • JavaScript操作localStorage實現(xiàn)保存本地json文件

    JavaScript操作localStorage實現(xiàn)保存本地json文件

    這篇文章主要為大家詳細介紹了JavaScript如何操作localStorage實現(xiàn)保存本地json文件,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-02-02
  • JavaScript多種頁面刷新方法小結

    JavaScript多種頁面刷新方法小結

    這篇文章主要介紹了JavaScript多種頁面刷新方法小結,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • 一個簡單不報錯的summernote 圖片上傳案例

    一個簡單不報錯的summernote 圖片上傳案例

    下面小編就為大家?guī)硪黄粋€簡單不報錯的summernote圖片上傳案例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • javascript頁面加載完執(zhí)行事件代碼

    javascript頁面加載完執(zhí)行事件代碼

    本篇文章主要是對javascript頁面加載完執(zhí)行事件的代碼進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-02-02
  • javascript閉包概念簡單解析(推薦)

    javascript閉包概念簡單解析(推薦)

    下面小編就為大家?guī)硪黄猨avascript閉包概念簡單解析(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 用js實現(xiàn)before和after偽類的樣式修改的示例代碼

    用js實現(xiàn)before和after偽類的樣式修改的示例代碼

    本篇文章主要介紹了用js實現(xiàn)before和after偽類的樣式修改的示例代碼,具有一定的參考價值,有興趣的可以了解一下
    2017-09-09
  • 微信小程序實現(xiàn)手勢滑動效果

    微信小程序實現(xiàn)手勢滑動效果

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)手勢滑動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08

最新評論