您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關判斷JS數據類型的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
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); // number console.log(typeof 'Hello'); // string console.log(typeof []); // object console.log(typeof {}); // object console.log(typeof doSomething); // function console.log(typeof true); // boolean console.log(typeof new Date()); // object console.log(typeof new RegExp()); // object console.log(typeof JSON.stringify({ name: 'zhencanhua' })); // string console.log(typeof null); // object console.log(typeof undefined); // undefined console.log(typeof (new Error('error!'))); // object console.log(typeof a); // undefined console.log(typeof Symbol()); // symbol console.log(typeof new Set()); // object console.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); // true console.log(arr1 instanceof Object); // true,Array 是Object的子類 console.log(obj1 instanceof Object); // true console.log(obj1 instanceof Array); // false console.log(Persion instanceof Function, Persion instanceof Object); // true true console.log(null instanceof Object); // false console.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, false console.log(str2 instanceof String, str2 instanceof Object); // true, true console.log(str3 instanceof String, str3 instanceof Object); // true, true console.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方法被調用時執行下面的操作步驟:
[[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)); // Boolean console.log(getTypeName()); // Undefined console.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; // true obj.constructor === Object; // true date.constructor === Date; // true str.constructor === String; // true getName.constructor === Function; // true sym.constructor === Symbol; // true set.constructor === Set; // true map.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; // true Stuent.prototype.constructor === Stuent; // false
關于判斷JS數據類型的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。