JavaScript和jQuery的類型判斷

此博文爲原創,轉載請註明出處!數組

對於類型的判斷,JavaScript用typeof來進行。工具

栗子:spa

console.log(typeof null);            //object
console.log(typeof []);              //object
console.log(typeof {});              //object
console.log(typeof new Date());      //object
console.log(typeof new Object);      //object
console.log(typeof function(){});    //function
console.log(typeof alert);           //function
console.log(typeof 1);               //number
console.log(typeof "abc");           //string
console.log(typeof true);            //boolean

能夠看到,typeof並不可以準確的判斷出每一種數據類型,好比null和數組等都是object類型。所以,JavaScript判斷數據類型不推薦使用typeof。code

那麼要如何具體判斷呢??看一下語法<( ̄3 ̄)> !blog

{}.toString.call(obj);

栗子:ip

console.log({}.toString.call(null));            //[object Null]
console.log({}.toString.call([]));              //[object Array]
console.log({}.toString.call({}));              //[object Object]
console.log({}.toString.call(new Date()));      //[object Date]
console.log({}.toString.call(function(){}));    //[object Function]
console.log({}.toString.call(new Object));      //[object Object]
console.log({}.toString.call(alert));           //[object Function]
console.log({}.toString.call(1));               //[object Number]
console.log({}.toString.call('abc'));           //[object String]
console.log({}.toString.call(true));            //[object Boolean]

哈哈,是否是一目瞭然呀!!源碼

那若是你用的是jQuery,就不用這麼麻煩嘍,能夠直接用工具方法$.type(),進行判斷string

栗子:io

console.log($.type(null));                  //null
console.log($.type([]));                    //array
console.log($.type({}));                    //object
console.log($.type(1));                     //number
......不全寫完了,結果和
{}.toString.call(obj);是同樣的
實際上{}.toString.call(obj);就是jQuery中$.type()這個工具方法的實現最重要的一段代碼(⊙o⊙)哦,神奇吧!趕快去jQuery源碼中找找看吧~~

若是哪裏寫的有問題,歡迎各路大神指正!
相關文章
相關標籤/搜索