日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JS數據類型判斷的幾種常用方法

瀏覽:225日期:2024-05-01 08:12:49

JavaScript 中常見數據類型有Number、String、Boolean、Object、Array、Json、Function、Date、RegExp、Error、undefined、Null等十幾種。ES6還有新增的數據類型有Symbol、Set、Map等。在實際應用中,我們經常需要判斷數據類型,現在我歸納幾種方法,希望對大家有所幫助。

typeof 判斷(最常用)

typeof 是 JS 提供的一個運算符,專門用來檢測一個變量的類型 。 typeof 有2種使用方式:typeof(表達式)和typeof 變量名,第一種是對表達式做運算,第二種是對變量做運算。

function doSomething() { console.log(’Hello World!’);}console.log(typeof 1); // numberconsole.log(typeof ’Hello’); // stringconsole.log(typeof []); // objectconsole.log(typeof {}); // objectconsole.log(typeof doSomething); // functionconsole.log(typeof true); // booleanconsole.log(typeof new Date()); // objectconsole.log(typeof new RegExp()); // objectconsole.log(typeof JSON.stringify({ name: ’zhencanhua’})); // stringconsole.log(typeof null); // objectconsole.log(typeof undefined); // undefinedconsole.log(typeof (new Error(’error!’))); // objectconsole.log(typeof a); // undefinedconsole.log(typeof Symbol()); // symbolconsole.log(typeof new Set()); // objectconsole.log(typeof new Map()); // object

從上面打印結果可以看出,typeof 不能區分引用型數據的類型和 null。另我們可以使用 Array.isArray(arr) 將數組類型的數據從中篩選出來。

instanceof 判斷(了解)

instanceof 用來檢測構造函數的 prototype 屬性是否出現在某個實例對象的原型鏈上。 語法:object(實例對象) instanceof constructor(構造函數)。是的話返回 true,否則返回 false。所以, instanceof 運算符只能用作對象的判斷。 針對 typeof 不能判斷的引用型數據,我們可以使用 instanceof 運算符。

let arr1 = [1, 2, 3];let obj1 = { name: ’小明’};function Persion() { }let persion1 = new Persion();console.log(arr1 instanceof Array); // trueconsole.log(arr1 instanceof Object); // true,Array 是Object的子類console.log(obj1 instanceof Object); // trueconsole.log(obj1 instanceof Array); // falseconsole.log(Persion instanceof Function, Persion instanceof Object); // true trueconsole.log(null instanceof Object); // falseconsole.log(persion1 instanceof Persion, persion1 instanceof Function, persion1 instanceof Object); // true false true// String對象和Date對象都屬于Object類型let str1 = ’Hello’;let str2 = new String();let str3 = new String(’你好’);let myDate = new Date();console.log(str1 instanceof String, str1 instanceof Object); // false, falseconsole.log(str2 instanceof String, str2 instanceof Object); // true, trueconsole.log(str3 instanceof String, str3 instanceof Object); // true, trueconsole.log(myDate instanceof Date, myDate instanceof Object); // true, true

從上面的判斷可以看出,instanceof 的使用限制很多,而且還不能很清晰方便的判斷出一個實例是數組還是對象或方法。

針對上面方法的弊端,我們可以使用 Object.prototype上的原生toString()方法來檢測數據的類型。

Object.prototype.toString.call() 判斷(最靠譜)

Object 是 JS 提供的原生對象, Object.prototype.toString對任何變量都會返回這樣一個字符串'[object class]',class 就是 JS 內置對象的構造函數的名字。 call是用來改變調用函數作用域的。

Object.prototype.toString() 在toString方法被調用時執行下面的操作步驟:

獲取this對象的[[Class]]屬性的值。(所以使用call來改變this的指向) 將字符串'[object ',第一步獲取的值, 以及 ']'拼接成新的字符串并返回。

[[Class]]是一個內部屬性,所有的對象(原生對象和宿主對象)都擁有該屬性。在規范中,[[Class]]是這么定義的: 內部屬性的描述, [[Class]] 是一個字符串值,表明了該對象的類型。

讀了上面的說明,用 call 的關鍵地方就在第1步,獲取的是 this 對象,不加 call 改變作用域時 this 指向的是Object.prototype。

function doSomething() { console.log(’Hello World!’);}// 使用Object.prototype.toString.call來判斷console.log(Object.prototype.toString.call(1)); // [object Number]console.log(Object.prototype.toString.call(’Hello’)); // [object String]console.log(Object.prototype.toString.call(false)); // [object Boolean]console.log(Object.prototype.toString.call({})); // [object Object]console.log(Object.prototype.toString.call([1, 2, 3])); // [object Array]console.log(Object.prototype.toString.call(new Error(’error!’))); // [object Error]console.log(Object.prototype.toString.call(new Date())); // [object Date]console.log(Object.prototype.toString.call(new RegExp())); // [object RegExp]console.log(Object.prototype.toString.call(doSomething)); // [object Function]console.log(Object.prototype.toString.call(null)); // [object Null]console.log(Object.prototype.toString.call(undefined)); // [object Undefined]console.log(Object.prototype.toString.call(JSON.stringify({ name: ’zhencanhau’}))); // [object String]console.log(Object.prototype.toString.call(Math)); // [object Math]console.log(Object.prototype.toString.call(Symbol(’abc’))); // [object Symbol]console.log(Object.prototype.toString.call(new Set())); // [object Set]console.log(Object.prototype.toString.call(new Map())); // [object Map]

但在實際應用時我們只想獲取返回的結果中數組的第二項,比如'[object Number]',我們只想要Number這段字符,那么我們可以寫個函數進行過濾:

// 通過定義一個公共函數獲取數據類型function getTypeName(val) { let str = Object.prototype.toString.call(val); return /^[object (.*)]$/.exec(str)[1];}console.log(getTypeName(false)); // Booleanconsole.log(getTypeName()); // Undefinedconsole.log(getTypeName(null)); // Null

上面的問題完美解決。

constructor 判斷(比較常用)

每一個對象實例都可以通過 constrcutor 對象來訪問它的構造函數 。JS 中內置了一些構造函數:Object、Array、Function、Date、RegExp、String等。我們可以通過數據的 constrcutor 是否與其構造函數相等來判斷數據的類型。

var arr = [];var obj = {};var date = new Date();var num = 110;var str = ’Hello’;var getName = function(){};var sym = Symbol();var set = new Set();var map = new Map();arr.constructor === Array; // trueobj.constructor === Object; // truedate.constructor === Date; // truestr.constructor === String; // truegetName.constructor === Function; // truesym.constructor === Symbol; // trueset.constructor === Set; // truemap.constructor === Map // true

但是這種方式仍然有個弊端,就是 constructor 所指向的的構造函數是可以被修改的。

function Name(name) { this.name = name;}function Stuent(age) { this.age = age;}// 將構造函數Name的實例賦給Student的原型,Student的原型的構造函數會發生改變,將不再指向自身。Stuent.prototype = new Name(’張三’);Stuent.prototype.constructor === Name; // trueStuent.prototype.constructor === Stuent; // false

以上就是我在項目中用到過的數據類型的判斷方法,具體使用哪一種,還需要根據自己的實際需求來判斷選擇。

到此這篇關于JS數據類型判斷的幾種常用方法的文章就介紹到這了,更多相關JS 數據類型判斷內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产欧美一区二区精品久久久| 亚洲欧美日本视频在线观看| 美国欧美日韩国产在线播放| 免费日韩视频| 亚洲欧美日韩国产一区| 首页亚洲欧美制服丝腿| 蜜臀av在线播放一区二区三区| 国产精品日韩久久久| 中文字幕亚洲精品乱码| 99久久九九| 中文一区一区三区免费在线观 | 日韩精品中文字幕一区二区| 亚洲三区欧美一区国产二区| 亚洲天堂日韩在线| 国产欧美日韩综合一区在线播放| 日韩黄色av| 国产黄色精品| 91精品啪在线观看国产18| 亚洲a一区二区三区| 免费在线看一区| 国产欧美激情| 91精品啪在线观看国产18| 亚洲综合另类| 精品一区91| 久久午夜精品一区二区| 国产欧美日韩精品一区二区三区| 高潮久久久久久久久久久久久久| 午夜国产欧美理论在线播放| 午夜精品福利影院| 神马日本精品| 蜜桃视频一区二区三区| 久久中文欧美| 亚洲欧美一级| 99久久婷婷| 老牛国内精品亚洲成av人片| 天使萌一区二区三区免费观看| 美女视频黄久久| 综合亚洲色图| 国产亚洲一区在线| 日韩综合在线| 日韩二区在线观看| 99pao成人国产永久免费视频| 国产精品99久久免费| 男人的天堂亚洲一区| 桃色av一区二区| 777久久精品| 免费观看久久久4p| 久久影院一区| 欧美一区久久久| 精品资源在线| 欧美1区2区3| 日本少妇精品亚洲第一区| 石原莉奈在线亚洲二区| 亚洲无线一线二线三线区别av| 精品黄色一级片| 久久99国产精品视频| 国产精品99久久免费| 国产精品极品| 美女视频黄久久| 精品免费视频| 欧美国产日本| 精品国产乱码| 一区二区精品伦理...| 久久精品毛片| 日韩网站中文字幕| av亚洲在线观看| 国产精品毛片在线看| 亚洲一区免费| 日精品一区二区三区| 91亚洲无吗| 美女高潮久久久| 一区二区三区四区日本视频| 国产精品久久久久久久免费观看| 高清日韩欧美| 欧美特黄一区| 黄色国产精品| 日本99精品| 精品一区二区三区四区五区| 久久久久一区| 日韩欧美四区| 日产精品一区二区| 久久先锋影音| 国产欧美亚洲精品a| 日韩大片在线播放| 三级在线观看一区二区 | 精品网站999| 五月天久久网站| 日韩精品1区2区3区| 精品国产一区二区三区噜噜噜| 久久一区二区三区喷水| 日本少妇一区二区| 久久久久国产一区二区| 日韩不卡一区二区| 国产中文一区| 国产极品模特精品一二| 极品日韩av| 狠狠久久伊人| 97久久超碰| 亚洲一区国产| 99久久夜色精品国产亚洲1000部| 国产欧美另类| 亚洲精品少妇| 99视频精品全国免费| 国产精品**亚洲精品| 蜜桃久久久久久| 欧美 日韩 国产一区二区在线视频| 欧美日韩调教| 日韩国产一二三区| 玖玖精品视频| 亚洲永久字幕| 亚洲精品在线观看91| 中文字幕系列一区| 久久中文精品| 国产乱码精品一区二区三区四区 | 四虎国产精品免费观看| 欧美私人啪啪vps| 蘑菇福利视频一区播放| 五月婷婷亚洲| 欧美日韩国产探花| 欧美日韩中文一区二区| 高清久久精品| 成人污污视频| av资源新版天堂在线| 久久精品午夜| 福利欧美精品在线| 国产精品久久久久久久免费观看 | 久久精品中文| 激情欧美一区二区三区| 99精品视频精品精品视频| 97精品在线| 91精品精品| 五月婷婷亚洲| 亚洲v天堂v手机在线| 天堂va在线高清一区| 亚洲网址在线观看| 日本中文字幕不卡| 欧美午夜三级| av资源中文在线天堂| 色在线视频观看| 欧美/亚洲一区| 亚洲精品综合| 久久成人福利| 久久婷婷亚洲| 亚洲香蕉久久| 国产不卡一区| 国产精品美女久久久| 青青国产91久久久久久| 久久精品国内一区二区三区| 日韩电影二区| 日本在线不卡视频| 91亚洲国产成人久久精品| 群体交乱之放荡娇妻一区二区| 精品1区2区3区4区| 国产精品99精品一区二区三区∴| 久久精品主播| 国产精品资源| 91成人超碰| 精品久久不卡| 日韩精品免费观看视频| 亚洲国产福利| 亚洲精品欧美| 久久三级福利| 欧美激情 亚洲a∨综合| 亚洲欧美视频一区二区三区| 老色鬼精品视频在线观看播放| 欧美日韩三区| 国产福利亚洲| 亚洲最大av| 激情久久五月| 国产h片在线观看| 欧美在线观看天堂一区二区三区| 成人在线网站| 国产一区2区在线观看| 亚洲精品乱码| 婷婷综合在线| 久久精品免费一区二区三区| 精品久久免费| 精品一区视频| 久久久国产精品网站| 日韩精品一区二区三区av| 尹人成人综合网| 色婷婷色综合| 精品中文字幕一区二区三区四区| 日韩1区2区3区| 一区二区三区午夜视频| 国产精品丝袜xxxxxxx| 免费毛片在线不卡| 99久久激情| 99国产精品视频免费观看一公开 | 国产欧美在线| 欧美日韩一二| 欧美日韩亚洲一区二区三区在线| 麻豆久久一区二区| 欧美成人综合| 美女国产精品| 精品国产精品国产偷麻豆| 老司机精品久久| 日韩精品91| 精品三级久久久| 日韩福利视频导航|