我們知道在js中有一個運算符可以幫助我們判斷一個值的類型,它就是typeof運算符。
console.log(typeof 123); //numberconsole.log(typeof '123'); //stringconsole.log(typeof true); //booleanconsole.log(typeof undefined); //undefinedconsole.log(typeof null); //objectconsole.log(typeof []); //objectconsole.log(typeof {}); //objectconsole.log(typeof function() {}); //function
我們從以上結果可以看出typeof的不足之處,它對于數值、字符串、布爾值分別返回number、string、boolean,函數返回function,undefined返回undefined,除此以外,其他情況都返回object。
所以如果返回值為object,我們是無法得知值的類型到底是數組還是對象或者其他值。為了準確得到每個值的類型,我們必須使用js中另一個運算符instanceof。下面簡單的說一下instanceof的用法。
instanceof運算符返回一個布爾值,表示指定對象是否為某個構造函數的實例。
instanceof運算符的左邊是實例對象,右邊是構造函數。它會檢查右邊構造函數的ptototype屬性,是否在左邊對象的原型鏈上。
var b = [];b instanceof Array //trueb 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); //numbergetValueType('123'); //stringgetValueType(true); //booleangetValueType(undefined); //undefinedgetValueType(null); //nullgetValueType([]); //arraygetValueType({}); //objectgetValueType(function(){}); //function
總結
以上所述是小編給大家介紹的JavaScript中如何判斷一個值的類型,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答