JavaScript中如何判斷一個值的類型
我們知道在js中有一個運(yùn)算符可以幫助我們判斷一個值的類型,它就是typeof運(yùn)算符。
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
我們從以上結(jié)果可以看出typeof的不足之處,它對于數(shù)值、字符串、布爾值分別返回number、string、boolean,函數(shù)返回function,undefined返回undefined,除此以外,其他情況都返回object。
所以如果返回值為object,我們是無法得知值的類型到底是數(shù)組還是對象或者其他值。為了準(zhǔn)確得到每個值的類型,我們必須使用js中另一個運(yùn)算符instanceof。下面簡單的說一下instanceof的用法。
instanceof運(yùn)算符返回一個布爾值,表示指定對象是否為某個構(gòu)造函數(shù)的實(shí)例。
instanceof運(yùn)算符的左邊是實(shí)例對象,右邊是構(gòu)造函數(shù)。它會檢查右邊構(gòu)造函數(shù)的ptototype屬性,是否在左邊對象的原型鏈上。
var b = []; b instanceof Array //true b instanceof Object //true
注意,instanceof運(yùn)算符只能用于對象,不適用原始類型的值。
所以我們可以結(jié)合typeof和instanceof運(yùn)算符的特性,來對一個值的類型做出較為準(zhǔn)確的判斷。
//得到一個值的類型 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
總結(jié)
以上所述是小編給大家介紹的JavaScript中如何判斷一個值的類型,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
普通web整合quartz跑定時(shí)任務(wù)的示例
這篇文章主要介紹了普通web整合quartz跑定時(shí)任務(wù),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03javascript漢字拼音互轉(zhuǎn)的簡單實(shí)例
下面小編就為大家?guī)硪黄猨avascript漢字拼音互轉(zhuǎn)的簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10JavaScript操作localStorage實(shí)現(xiàn)保存本地json文件
這篇文章主要為大家詳細(xì)介紹了JavaScript如何操作localStorage實(shí)現(xiàn)保存本地json文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02一個簡單不報(bào)錯的summernote 圖片上傳案例
下面小編就為大家?guī)硪黄粋€簡單不報(bào)錯的summernote圖片上傳案例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07用js實(shí)現(xiàn)before和after偽類的樣式修改的示例代碼
本篇文章主要介紹了用js實(shí)現(xiàn)before和after偽類的樣式修改的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09