舉例講解如何判斷JavaScript中對(duì)象的類型
在編寫js程序的過程中,可能常常需要判斷一個(gè)對(duì)象的類型,例如你寫了一個(gè)函數(shù),需要通過判斷不同的參數(shù)類型來(lái)編寫不同的代碼。
首先可能會(huì)想到typeof操作符,看下面的這個(gè)例子:
<script type="text/javascript"> var object = {}; var b = true; alert(typeof object + " " + typeof b); </script>
得到的結(jié)果如下:
從上面的結(jié)果可以看到,用typeof操作符可以顯示對(duì)象的類型,那么typeof操作符作用域null和undefined的結(jié)果會(huì)是什么呢?
/*var object = {}; var b = true; alert(typeof object + " " + typeof b);*/ alert(typeof null + " " + typeof undefined)
typeof 操作符作用于null居然顯示”object“(這個(gè)好像不科學(xué),我還以為會(huì)顯示”null'“),作用于undefined顯示”undefined“(這個(gè)符合我們希望的結(jié)果),所以當(dāng)用typeof操作符來(lái)判斷一個(gè)對(duì)象的類型時(shí),特別要小心,因?yàn)檫@個(gè)對(duì)象有可能是null。上面只是給了一部分typeof作用于這些對(duì)象的結(jié)果,下面的表列出了typeof操作符作用于Boolean, Number, String, Array, Date, RegExp, Object, Function, null, undefined的結(jié)果(有興趣的讀者可以自行測(cè)試):
從上表的結(jié)果可以看出Array, Date, RegExp顯示的都是object,為什么不是直接的顯示對(duì)象的類型呢?這就要引出js的另外一個(gè)操作符了:instanceof操作符,這個(gè)操作符用來(lái)判斷一個(gè)對(duì)象是否為某種類型的對(duì)象,計(jì)算的值為true或者false。先來(lái)看下:
var now = new Date(); var pattern = /^[\s\S]*$/; var names = ['zq', 'john']; alert((now instanceof Date) + " " + (pattern instanceof RegExp) + " " + (names instanceof Array));
很顯然通過這個(gè)instanceof是能判斷對(duì)象的類型的,但是這個(gè)只能判斷除了基本類型(包含String類型)的其它類型,他是不能判斷基本類型的。但是instanceof不是總是能正常判斷的,考慮一個(gè)框架的情形,要判斷其類型的對(duì)象是另外一個(gè)frame傳遞過來(lái)的對(duì)象,首先來(lái)看下下面的例子。
main.html
<!doctype html> <html lang="en"> <head> <title>Main</title> </head> <frameset cols="45%,*"> <frame name="frame1" src="frame1.html"/> <frame name="frame2" src="frame2.html"/> </frameset> </html>
frame1.html
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>frame1</title> </head> <script type="text/javascript"> var names = ['riccio zhang', 'zq', 'john']; </script> <body style="background: #ccc"> </body> </html>
frame2.html
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>frame2</title> <script type="text/javascript"> document.write("top.frame1.names instanceof Array:" + (top.frame1.names instanceof Array)); document.write("<br/>"); document.write("top.frame1.names instanceof top.frame1.Array:" + (top.frame1.names instanceof top.frame1.Array)); document.write("<br/>"); document.write("top.frame1.Array === top.frame2.Array?" + (top.frame1.Array === top.frame2.Array)); </script> </head> <body style="background: #747474"> </body> </html>
names對(duì)象是在frame1框架中的,此時(shí)是通過frame1框架的Array來(lái)創(chuàng)建的,如果把names對(duì)象拿到frame2中的Array作比較,很顯然names不是frame2中的Array的實(shí)例,以為frame1和frame2壓根就不是同一和Array,從第2個(gè)現(xiàn)實(shí)結(jié)果可以很明顯的看出names是他本身所在的frame的實(shí)例,從第3個(gè)輸出可以看出frame1的Array和frame2的Array是不同的。那么遇到上面這種跨frame的比較該怎么辦呢?我們總不能每次都拿框架對(duì)應(yīng)的Array來(lái)做比較吧,有一種必須的辦法可以解決上面的問題,看下面的代碼:
var toString = {}.toString; var now = new Date(); alert(toString.call(now))
{}.toString表示獲取Object對(duì)象上的toString方法(這個(gè)方法時(shí)Object對(duì)象的基本方法之一),toString.call(now)表示調(diào)用toString方法。調(diào)用Date對(duì)象最原生的toString()(這個(gè)方法是Object上面的方法)方法可以顯示[object Date]類型的字符串,假如是Array,則會(huì)產(chǎn)生[object Array]的字樣,也就是說(shuō)進(jìn)行上面的操作會(huì)顯示類似[object Class]的字樣,那么我們只要判斷這個(gè)字符串不就可以知道其類型了嗎?由此可以寫出如下的工具類:
tools.js
var tools = (function(undefined){ var class2type = {}, toString = {}.toString; var fun = { type: function (obj){ return obj === null || obj === undefined ? String(obj) : class2type[toString.call(obj)] }, isArray: function (obj){ return fun.type(obj) === "array"; }, isFunction: function (obj){ return fun.type(obj) === "function"; }, each: function (arr, callback){ var i = 0, hasLength = arr.length ? true : false; if(!callback || (typeof callback !== 'function') || !hasLength){ return; } for(i = 0; i< arr.length; i++){ if(callback.call(arr[i], i, arr[i]) === false){ break; } } } }; fun.each("Boolean Number String Array Date RegExp Object Function".split(" "), function(i, name){ class2type["[object "+ name +"]"] = name.toLowerCase(); }); return fun; })();
tools提供了type,isArray,isFunction等方法用來(lái)判斷對(duì)象的類型,根據(jù)實(shí)際的需要可以自己添加需要判斷類型的方法。type接受一個(gè)obj參數(shù),它將對(duì)象的實(shí)際類型以小寫的形式返回,比如你的需要判斷對(duì)象的類型是Array,那么此方法將會(huì)返回array.
根據(jù)上面提供的工具類,再重新改寫上面的例子:
fram2.html
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>frame2</title> <script type="text/javascript" src="tools.js"></script> <script type="text/javascript"> document.write("top.frame1.names instanceof Array:" + (top.frame1.names instanceof Array)); document.write("<br/>"); document.write("top.frame1.names instanceof top.frame1.Array:" + (top.frame1.names instanceof top.frame1.Array)); document.write("<br/>"); document.write("top.frame1.Array === top.frame2.Array?" + (top.frame1.Array === top.frame2.Array)); document.write("<br/>"); document.write("tools.isArray(top.frame1.names)?" + tools.isArray(top.frame1.names)); </script> </head> <body style="background: #747474"> </body> </html>
至此通過上面的根據(jù)類就可以很容易的判斷對(duì)象的類型了。
注意:在IE中例如像alert這樣的元素是不能判斷的。
- JavaScript中判斷變量是數(shù)組、函數(shù)或是對(duì)象類型的方法
- JavaScript中判斷對(duì)象類型的幾種方法總結(jié)
- json轉(zhuǎn)String與String轉(zhuǎn)json及判斷對(duì)象類型示例代碼
- js確定對(duì)象類型方法
- JavaScript isArray()函數(shù)判斷對(duì)象類型的種種方法
- isArray()函數(shù)(JavaScript中對(duì)象類型判斷的幾種方法)
- JavaScript使用prototype定義對(duì)象類型
- JavaScript使用prototype定義對(duì)象類型(轉(zhuǎn))[
相關(guān)文章
Javascript 按位左移運(yùn)算符使用介紹(<<)
這篇文章主要介紹了Javascript 按位左移運(yùn)算符 (<<) 將表達(dá)式數(shù)字轉(zhuǎn)換成二進(jìn)制,之后向左移表達(dá)式的位的相關(guān)資料,需要的朋友可以參考下2014-02-02分享javascript實(shí)現(xiàn)的冒泡排序代碼并優(yōu)化
本文給大家匯總介紹了幾個(gè)個(gè)人收藏的JavaScript實(shí)現(xiàn)冒泡排序的代碼,都是非常的不錯(cuò),有需要的小伙伴可以參考下2016-06-06關(guān)于JavaScript的Array數(shù)組方法詳解
這篇文章主要介紹了關(guān)于JavaScript的Array數(shù)組方法詳解,數(shù)組是一個(gè)固定長(zhǎng)度的存儲(chǔ)相同數(shù)據(jù)類型的數(shù)據(jù)結(jié)構(gòu),數(shù)組中的元素被存儲(chǔ)在一段連續(xù)的內(nèi)存空間中,它是最簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu)之一,需要的朋友可以參考下2023-05-05javascript學(xué)習(xí)(一)構(gòu)建自己的JS庫(kù)
庫(kù)是一個(gè)飽受爭(zhēng)議的熱門話題。一種觀點(diǎn)認(rèn)為它是一種非常棒的工具,是任何開發(fā)者都不可或缺的;另一種觀點(diǎn)則認(rèn)為在不理解庫(kù)的內(nèi)部工作原理的情況下對(duì)庫(kù)形成依賴,會(huì)助長(zhǎng)懶惰的風(fēng)氣從而導(dǎo)致開發(fā)者素質(zhì)下降2013-01-01javascript中的throttle和debounce淺析
這篇文章主要介紹了javascript中的throttle和debounce淺析,分別介紹了throttle和debounce的使用場(chǎng)景及具體案例,需要的朋友可以參考下2014-06-06深入解析JavaScript中的arguments對(duì)象
arguments是JavaScript里的一個(gè)內(nèi)置對(duì)象,像數(shù)組結(jié)構(gòu)一樣存儲(chǔ)參數(shù)的傳遞,這里我們就來(lái)深入解析JavaScript中的arguments對(duì)象,需要的朋友可以參考下2016-06-06關(guān)于session和cookie的簡(jiǎn)單理解
下面小編就為大家?guī)?lái)一篇關(guān)于session和cookie的簡(jiǎn)單理解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2016-06-06