成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JS中必須知道的四種數據類型判斷方法

開發 前端
js有多種數據類型(Number(數值)、String(字符串)、Boolean(布爾值)、Null、Undefined、Symbol、Object、函數等),在開發過程中難免需要判斷數據類型,本文總結了四種判斷方法.

[[433821]]

js有多種數據類型(Number(數值)、String(字符串)、Boolean(布爾值)、Null、Undefined、Symbol、Object、函數等),在開發過程中難免需要判斷數據類型,本文總結了四種判斷方法:

 typeof

typeof是一個運算符,其有兩種使用方式:(1)typeof(表達式);(2)typeof 變量名;返回值是一個字符串,用來說明變量的數據類型;所以可以用此來判斷number, string, object, boolean, function, undefined, symbol 這七種類型,每種情況返回的內容如下表所示:(具體進階可看前端百題斬【001】) 

 

小試牛刀 

  1. // 字符串 
  2. console.log(typeof('lili')); // string 
  3. // 數字 
  4. console.log(typeof(1)); // number 
  5. // 布爾值 
  6. console.log(typeof(true)); // boolean 
  7. // undefined 
  8. console.log(typeof(undefined)); // undefined 
  9. // 對象 
  10. console.log(typeof({})); // object 
  11. // 數組 
  12. console.log(typeof([])); // object 
  13. // null 
  14. console.log(typeof(null)); // object 
  15. // 函數 
  16. console.log(typeof(() => {})); // function 
  17. // Symbol值 
  18. console.log(typeof(Symbol())); // symbol 

instanceof

instanceof運算符用于檢測構造函數的 prototype屬性是否出現在某個實例對象的原型鏈上,返回值為布爾值,用于指示一個變量是否屬于某個對象的實例。其語法如下所示:(具體進階可看前端百題斬【001】) 

  1. object instanceof constructor 

小試牛刀 

  1. const arr = [1, 2]; 
  2. // 判斷Object的prototype有沒有在數組的原型鏈上 
  3. console.log(arr instanceof Object); // true 
  4. // 數組arr的原型 
  5. const proto1 = Object.getPrototypeOf(arr); 
  6. console.log(proto1); // [] 
  7. // 數組arr的原型的原型 
  8. const proto2 = Object.getPrototypeOf(proto1); 
  9. console.log(proto2); // [] 
  10. // Object的prototype 
  11. console.log(Object.prototype); 
  12. // 判斷arr的原型是否與Object的prototype相等 
  13. console.log(proto1 === Object.prototype); // false 
  14. // 判斷arr的原型的原型是否與Object的prototype相等 
  15. console.log(proto2 === Object.prototype); // true 

 constructor

該種判斷方式其實涉及到原型、構造函數和實例之間的關系,更深層次的講解將放到后面的內容,下面只需要簡單了解一下這三者關系即可。 

 

在定義一個函數(構造函數)的時候,JS引擎會為其添加prototype原型,原型上有其對應的constructor屬性指向該構造函數,從而原型和構造函數之間互相知道對方。當構造函數實例化的時候,會產生對應的實例,其實例可以訪問對應原型上的constructor屬性,這樣該實例就可以了解到通過誰產生了自己,這樣就可以在新對象產生之后了解其數據類型。

小試牛刀 

  1. const val1 = 1; 
  2. console.log(val1.constructor); // [Function: Number] 
  3. const val2 = 'abc'
  4. console.log(val2.constructor); // [Function: String] 
  5. const val3 = true
  6. console.log(val3.constructor); // [Function: Boolean] 

雖然該方法可以判斷其數據類型,但存在兩個缺點:

  1. null 和 undefined 是無效的對象,因此是不會有 constructor 存在的,這兩種類型的數據需要通過其他方式來判斷。
  2. 函數的 constructor 是不穩定的,這個主要體現在自定義對象上,當開發者重寫 prototype 后,原有的 constructor 引用會丟失,constructor 會默認為 Object

 toString()

toString() 是 Object 的原型方法,調用該方法,默認返回當前對象的 [[Class]] 。這是一個內部屬性,其格式為[object Xxx] ,其中 Xxx 就是對象的類型。所以利用Object.prototype.toString()方法可以對變量的類型進行比較準確的判斷。該類型針對不同不同變量的類型返回的結果如下所示: 

 

利用該方法很容易構建一個鑒型函數,代碼如下所示: 

  1. function type(target) { 
  2.     const ret = typeof(target); 
  3.     const template = { 
  4.         "[object Array]""array",  
  5.         "[object Object]":"object"
  6.         "[object Number]":"number - object"
  7.         "[object Boolean]":"boolean - object"
  8.         "[object String]":'string-object' 
  9.     } 
  10.     if(target === null) { 
  11.         return 'null'
  12.     } 
  13.     else if(ret == "object"){ 
  14.         const str = Object.prototype.toString.call(target); 
  15.         return template[str]; 
  16.     } 
  17.     else
  18.         return ret; 
  19.     } 

小試牛刀 

  1. console.log(type({})); // object 
  2. console.log(type(123)); // number 
  3. console.log(type('123')); // string 

 

責任編輯:姜華 來源: 前端點線面
相關推薦

2016-11-10 13:00:32

網絡傳輸協議pythonhttp

2015-07-23 14:50:28

大數據

2020-04-02 15:37:58

數據結構存儲

2023-01-10 08:12:52

Java程序員負載均衡

2022-10-27 09:50:41

數據倉開發

2021-03-12 08:02:34

Redis數據類型.

2016-08-01 10:42:58

數據類型WebWordPress

2010-05-26 17:05:48

MySQL數據類型

2014-04-25 09:38:08

大數據

2009-02-25 09:52:14

類型轉換.NET 強制轉型

2020-07-24 09:56:12

React開發數據

2009-06-09 10:05:41

jQuery

2020-12-29 09:50:23

大數據大數據技術

2021-10-24 08:37:18

網絡監控網絡架構網絡

2022-12-15 08:00:00

2020-03-19 15:30:08

JavaScript數組字符串

2023-11-01 08:01:48

數據結構軟件工程

2024-03-29 13:17:03

Docker數據卷Volume

2020-05-19 20:13:04

物聯網計算類型IOT

2022-03-25 14:47:24

Javascript數據類型開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲性视频在线 | 国产极品粉嫩美女呻吟在线看人 | 亚洲精彩视频在线观看 | 国产精品99 | 国产午夜av片 | 免费成人高清在线视频 | 亚洲精品一区在线 | 亚洲欧美日韩电影 | 国产日韩欧美精品 | 欧美精品一区二区在线观看 | 免费激情av| 国产伦一区二区三区 | 99看片网| 免费网站国产 | 久久精品无码一区二区三区 | 天天天天操 | 成人午夜激情 | 中文一区 | 伊人久久综合 | 亚洲自拍一区在线观看 | 亚洲视频在线看 | 日韩网站免费观看 | 精久久久| 中文字幕在线国产 | 伦理午夜电影免费观看 | 91麻豆精品国产91久久久更新资源速度超快 | 一区二区三区精品 | 久草精品视频 | 国产激情小视频 | 天天干天天插 | 精品欧美一区免费观看α√ | 久久亚洲一区 | 亚洲精品一二三 | 日韩欧美国产一区二区三区 | 久久久久久久久久久一区二区 | 免费观看一级特黄欧美大片 | 91麻豆精品国产91久久久更新资源速度超快 | 91精品国产综合久久福利软件 | 中国xxxx性xxxx产国 | 久久精品亚洲 | 欧美老少妇一级特黄一片 |