亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 10:13:48
字體:
來源:轉載
供稿:網友

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

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

得到的結果如下:

2016422170645689.png (377×220)

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

/*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“(這個符合我們希望的結果),所以當用typeof操作符來判斷一個對象的類型時,特別要小心,因為這個對象有可能是null。上面只是給了一部分typeof作用于這些對象的結果,下面的表列出了typeof操作符作用于Boolean, Number, String, Array, Date, RegExp, Object, Function, null, undefined的結果(有興趣的讀者可以自行測試):

2016422170736411.png (504×291)

從上表的結果可以看出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來創建的,如果把names對象拿到frame2中的Array作比較,很顯然names不是frame2中的Array的實例,以為frame1和frame2壓根就不是同一和Array,從第2個現實結果可以很明顯的看出names是他本身所在的frame的實例,從第3個輸出可以看出frame1的Array和frame2的Array是不同的。那么遇到上面這種跨frame的比較該怎么辦呢?我們總不能每次都拿框架對應的Array來做比較吧,有一種必須的辦法可以解決上面的問題,看下面的代碼:

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

2016422170910729.png (345×186)

{}.toString表示獲取Object對象上的toString方法(這個方法時Object對象的基本方法之一),toString.call(now)表示調用toString方法。調用Date對象最原生的toString()(這個方法是Object上面的方法)方法可以顯示[object Date]類型的字符串,假如是Array,則會產生[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等方法用來判斷對象的類型,根據實際的需要可以自己添加需要判斷類型的方法。type接受一個obj參數,它將對象的實際類型以小寫的形式返回,比如你的需要判斷對象的類型是Array,那么此方法將會返回array.
根據上面提供的工具類,再重新改寫上面的例子:
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)

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产91精品不卡视频| 色综合久久88| 久久久精品久久久久| 超在线视频97| 亚洲美女av在线| 欧美成人h版在线观看| 欧美在线观看www| 亚洲精品国产精品国自产观看浪潮| 久青草国产97香蕉在线视频| www.久久久久久.com| 91色p视频在线| 亚洲国产日韩欧美综合久久| 全亚洲最色的网站在线观看| 一区二区三区黄色| 中文字幕亚洲一区在线观看| 精品国产一区二区三区久久久狼| 成人久久精品视频| 91最新国产视频| 中文字幕精品网| 欧美激情视频免费观看| 欧美整片在线观看| 久久九九热免费视频| 国产成人啪精品视频免费网| 久久久国产一区| 亚洲免费小视频| 深夜精品寂寞黄网站在线观看| 亚洲香蕉成视频在线观看| 国产成人精品av| 日韩中文综合网| 欧美亚洲免费电影| 久久手机精品视频| 日韩av在线免播放器| 国产成人97精品免费看片| 亚洲成人黄色在线观看| 91精品国产综合久久香蕉的用户体验| 欧美精品第一页在线播放| 91香蕉亚洲精品| 久久久精品国产亚洲| 国产一区二区三区在线播放免费观看| 国产视频亚洲视频| 久久av红桃一区二区小说| 精品动漫一区二区三区| 亚洲欧美日韩国产中文| 亚洲综合日韩中文字幕v在线| 久久人91精品久久久久久不卡| 亚洲视频在线免费观看| 欧美精品在线播放| 国产成人亚洲精品| 久久久久久美女| 国产91久久婷婷一区二区| 成人久久18免费网站图片| 日韩成人中文字幕在线观看| 亚洲激情小视频| 夜夜狂射影院欧美极品| 中文字幕av日韩| 欧美福利视频在线观看| 成人精品视频久久久久| 国产偷国产偷亚洲清高网站| 97国产精品人人爽人人做| 91国内产香蕉| 成人激情综合网| 91久久国产精品91久久性色| 清纯唯美日韩制服另类| 亚洲a区在线视频| 久久亚洲综合国产精品99麻豆精品福利| 欧洲亚洲在线视频| 亚洲视频在线免费观看| 91沈先生在线观看| 亚洲美女喷白浆| 日韩在线中文视频| 在线观看国产成人av片| 成人h片在线播放免费网站| 成人在线观看视频网站| 亚洲国产精品一区二区久| 欧美大全免费观看电视剧大泉洋| 日韩精品久久久久久福利| 亚洲激情电影中文字幕| 国内精品久久久久久中文字幕| 69av视频在线播放| 精品国产乱码久久久久久虫虫漫画| 一区二区欧美亚洲| 亚洲国产精品女人久久久| 成人国产在线激情| 国产欧美一区二区三区在线看| 欧洲日本亚洲国产区| 日韩高清人体午夜| 欧美中文在线观看国产| 久久免费高清视频| 久久97精品久久久久久久不卡| 欧美精品一区二区免费| 国产精品一区av| 亚洲成人性视频| www.99久久热国产日韩欧美.com| 97国产suv精品一区二区62| 日韩av在线免费观看一区| 国产美女精品视频| 最近2019中文字幕第三页视频| 久久91亚洲人成电影网站| 国产精品久久在线观看| 亚洲精品99999| 久久久电影免费观看完整版| 欧美日韩福利在线观看| 韩国v欧美v日本v亚洲| 日韩欧美精品中文字幕| 欧美黄网免费在线观看| 中文字幕国产精品| 欧美亚洲成人精品| 日韩av在线看| 国产欧美精品日韩精品| 亚洲xxxx妇黄裸体| 亚洲福利影片在线| 亚洲第一免费网站| 亚洲精品不卡在线| 欧美专区在线观看| 国产精品久久久久9999| 国产午夜精品美女视频明星a级| 性色av一区二区三区免费| 欧洲中文字幕国产精品| 国产精品自拍视频| 成人黄色av网站| 国产在线视频91| 亚洲人成欧美中文字幕| 91精品久久久久久久久久入口| 亚洲综合中文字幕68页| 欧美激情亚洲激情| 欧美大片免费观看在线观看网站推荐| 日韩精品免费在线视频观看| 久久久久久久久爱| 亚洲国产成人精品女人久久久| 国产精品久久电影观看| 美女av一区二区| 亚州欧美日韩中文视频| 精品成人国产在线观看男人呻吟| 国产精品自产拍高潮在线观看| 日本精品中文字幕| 国产不卡视频在线| 久久久成人av| 国产精品久久久精品| 永久免费精品影视网站| 91在线视频免费| 亚洲最新在线视频| 啊v视频在线一区二区三区| 国产v综合ⅴ日韩v欧美大片| 久久九九全国免费精品观看| 久久影院中文字幕| 亚洲女人天堂av| 欧美大秀在线观看| 久久久久久久久电影| 91色在线观看| www.欧美精品一二三区| 国产日韩在线视频| 欧美一级成年大片在线观看| 亚洲18私人小影院| 久久亚洲春色中文字幕| 亚洲一区二区三区视频播放| 国产精品欧美激情| 成人97在线观看视频| 国产精品综合网站| 国产精品va在线播放我和闺蜜| 亚洲精品国精品久久99热| 亚洲第一视频在线观看| 国产日韩在线免费| 国产精品吊钟奶在线| 国产亚洲一区二区精品|