欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

舉例講解如何判斷JavaScript中對象的類型

 更新時間:2016年04月22日 17:12:20   投稿:goldensun  
這篇文章主要介紹了如何判斷JavaScript中對象的類型,舉例講解了使用typeof和instanceof等操作符來進行判斷的方法,需要的朋友可以參考下

在編寫js程序的過程中,可能常常需要判斷一個對象的類型,例如你寫了一個函數(shù),需要通過判斷不同的參數(shù)類型來編寫不同的代碼。
首先可能會想到typeof操作符,看下面的這個例子:

 <script type="text/javascript"> 
var object = {}; 
var b = true; 
alert(typeof object + " " + typeof b); 
 </script> 

得到的結(jié)果如下:

2016422170645689.png (377×220)

從上面的結(jié)果可以看到,用typeof操作符可以顯示對象的類型,那么typeof操作符作用域null和undefined的結(jié)果會是什么呢?

/*var object = {}; 
var b = true; 
alert(typeof object + " " + typeof b);*/ 
alert(typeof null + " " + typeof undefined) 

2016422170716617.png (239×143)

typeof 操作符作用于null居然顯示”object“(這個好像不科學,我還以為會顯示”null'“),作用于undefined顯示”undefined“(這個符合我們希望的結(jié)果),所以當用typeof操作符來判斷一個對象的類型時,特別要小心,因為這個對象有可能是null。上面只是給了一部分typeof作用于這些對象的結(jié)果,下面的表列出了typeof操作符作用于Boolean, Number, String, Array, Date, RegExp, Object, Function, null, undefined的結(jié)果(有興趣的讀者可以自行測試):

2016422170736411.png (504×291)

從上表的結(jié)果可以看出Array, Date, RegExp顯示的都是object,為什么不是直接的顯示對象的類型呢?這就要引出js的另外一個操作符了:instanceof操作符,這個操作符用來判斷一個對象是否為某種類型的對象,計算的值為true或者false。先來看下:

var now = new Date(); 
var pattern = /^[\s\S]*$/; 
var names = ['zq', 'john']; 
alert((now instanceof Date) + " " 
 + (pattern instanceof RegExp) + " " + (names instanceof Array)); 

2016422170805336.png (385×281)

很顯然通過這個instanceof是能判斷對象的類型的,但是這個只能判斷除了基本類型(包含String類型)的其它類型,他是不能判斷基本類型的。但是instanceof不是總是能正常判斷的,考慮一個框架的情形,要判斷其類型的對象是另外一個frame傳遞過來的對象,首先來看下下面的例子。
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> 

2016422170849229.png (1365×215)

names對象是在frame1框架中的,此時是通過frame1框架的Array來創(chuàng)建的,如果把names對象拿到frame2中的Array作比較,很顯然names不是frame2中的Array的實例,以為frame1和frame2壓根就不是同一和Array,從第2個現(xiàn)實結(jié)果可以很明顯的看出names是他本身所在的frame的實例,從第3個輸出可以看出frame1的Array和frame2的Array是不同的。那么遇到上面這種跨frame的比較該怎么辦呢?我們總不能每次都拿框架對應(yīng)的Array來做比較吧,有一種必須的辦法可以解決上面的問題,看下面的代碼:

var toString = {}.toString; 
var now = new Date(); 
alert(toString.call(now)) 

2016422170910729.png (345×186)

{}.toString表示獲取Object對象上的toString方法(這個方法時Object對象的基本方法之一),toString.call(now)表示調(diào)用toString方法。調(diào)用Date對象最原生的toString()(這個方法是Object上面的方法)方法可以顯示[object Date]類型的字符串,假如是Array,則會產(chǎn)生[object Array]的字樣,也就是說進行上面的操作會顯示類似[object Class]的字樣,那么我們只要判斷這個字符串不就可以知道其類型了嗎?由此可以寫出如下的工具類:
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等方法用來判斷對象的類型,根據(jù)實際的需要可以自己添加需要判斷類型的方法。type接受一個obj參數(shù),它將對象的實際類型以小寫的形式返回,比如你的需要判斷對象的類型是Array,那么此方法將會返回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> 

2016422171011812.png (1363×189)

至此通過上面的根據(jù)類就可以很容易的判斷對象的類型了。
注意:在IE中例如像alert這樣的元素是不能判斷的。

相關(guān)文章

  • Javascript 按位左移運算符使用介紹(<<)

    Javascript 按位左移運算符使用介紹(<<)

    這篇文章主要介紹了Javascript 按位左移運算符 (<<) 將表達式數(shù)字轉(zhuǎn)換成二進制,之后向左移表達式的位的相關(guān)資料,需要的朋友可以參考下
    2014-02-02
  • 分享javascript實現(xiàn)的冒泡排序代碼并優(yōu)化

    分享javascript實現(xiàn)的冒泡排序代碼并優(yōu)化

    本文給大家匯總介紹了幾個個人收藏的JavaScript實現(xiàn)冒泡排序的代碼,都是非常的不錯,有需要的小伙伴可以參考下
    2016-06-06
  • 關(guān)于JavaScript的Array數(shù)組方法詳解

    關(guān)于JavaScript的Array數(shù)組方法詳解

    這篇文章主要介紹了關(guān)于JavaScript的Array數(shù)組方法詳解,數(shù)組是一個固定長度的存儲相同數(shù)據(jù)類型的數(shù)據(jù)結(jié)構(gòu),數(shù)組中的元素被存儲在一段連續(xù)的內(nèi)存空間中,它是最簡單的數(shù)據(jù)結(jié)構(gòu)之一,需要的朋友可以參考下
    2023-05-05
  • javascript學習(一)構(gòu)建自己的JS庫

    javascript學習(一)構(gòu)建自己的JS庫

    庫是一個飽受爭議的熱門話題。一種觀點認為它是一種非常棒的工具,是任何開發(fā)者都不可或缺的;另一種觀點則認為在不理解庫的內(nèi)部工作原理的情況下對庫形成依賴,會助長懶惰的風氣從而導致開發(fā)者素質(zhì)下降
    2013-01-01
  • javascript中的throttle和debounce淺析

    javascript中的throttle和debounce淺析

    這篇文章主要介紹了javascript中的throttle和debounce淺析,分別介紹了throttle和debounce的使用場景及具體案例,需要的朋友可以參考下
    2014-06-06
  • Es6 寫的文件import 起來解決方案詳解

    Es6 寫的文件import 起來解決方案詳解

    這篇文章主要介紹了如何讓es6 寫的文件import 起來詳解的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • 常用一些Javascript判斷函數(shù)

    常用一些Javascript判斷函數(shù)

    常用一些Javascript判斷函數(shù),都是一些js基礎(chǔ)知識,學習js的朋友可以看下
    2012-08-08
  • 深入解析JavaScript中的arguments對象

    深入解析JavaScript中的arguments對象

    arguments是JavaScript里的一個內(nèi)置對象,像數(shù)組結(jié)構(gòu)一樣存儲參數(shù)的傳遞,這里我們就來深入解析JavaScript中的arguments對象,需要的朋友可以參考下
    2016-06-06
  • JavaScript從原型到原型鏈深入理解

    JavaScript從原型到原型鏈深入理解

    這篇文章主要介紹了從原型與原型鏈開始講起,如果你想知道構(gòu)造函數(shù)的實例的原型,原型的原型,原型的原型的原型是什么,就來看看這篇文章吧。下面小編就來帶大家一起學習一下
    2019-06-06
  • 關(guān)于session和cookie的簡單理解

    關(guān)于session和cookie的簡單理解

    下面小編就為大家?guī)硪黄P(guān)于session和cookie的簡單理解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06

最新評論