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

首頁 > 編程 > JavaScript > 正文

JavaScript數據類型判定的總結筆記

2019-11-20 11:56:49
字體:
來源:轉載
供稿:網友

用typeof 來檢測數據類型
Javascript自帶兩套類型:基本數據類型(undefined,string,null,boolean,function,object)和對象類型。

但是如果嘗試用typeof 來檢測對象類型都一律返回"object"并不能加以區分

typeof null // "object"typeof []  // "object"typeof document.childNodes //"object"typeof //d/ //"object"typeof new Number() //"object"

用constructor 屬性來檢測類型的構造函數

[].constructor === Array  //truedocument.childNodes === NodeList  //true//d/.constructor === RegExp   //true function isRegExp(obj) {  return obj && typeof obj === "object" && obj.constructor === RegExp;} //檢測正則表達式對象 function isNull(obj){  return obj === null;}

用construct檢測可以完成大多數的類型檢測,null特殊直接比較。然而iframe中的數組類型確無法檢測出正確類型,這是用construct檢測的一個缺陷;同時在舊版本IE下DOM和BOM的construct是無法訪問的

利用 Object.prototype.toString 來判斷

Object.prototype.toString.call([]) //"[object Array]"Object.prototype.toString.call(//d/) // "[object RegExp]"Object.prototype.toString.call(1)//"[object Number]"

來看看jQuery源碼中是如何使用toString方法的

/** jQuery JavaScript Library v1.11.2*/var class2type = {};  //用來保存js數據類型 jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) {//構造class2type存儲常用類型的映射關系,遍歷基本類型并賦值,鍵值為 [object 類型] class2type[ "[object " + name + "]" ] = name.toLowerCase();});type: function( obj ) {  if ( obj == null ) {//首先如果是null則返回null字符串   return obj + "";  }//接著判斷給定參數類型是否為object或者function,是的話在映射表中尋找 toString后的鍵值名稱并返回,不是的話利用typeof就可以得到正確類型。  return typeof obj === "object" || typeof obj === "function" ?   class2type[ toString.call(obj) ] || "object" :   typeof obj; },/****************************/ jQuery.type(//d/)  //"regexp"jQuery.type(new Number())  //"number"

這里能夠使用toString方法來檢測是因為不同對象都會重新定義自己的toString方法

說說一些特殊類型的檢測

上述調試是在IE8中進行的,因為undefined 在javascript中并不是關鍵字,在IE8以下(之后的版本不可以賦值)是可以賦值的,查看jQuery.type源碼可知,對于 undefined檢測由是 typeof undefined完成的。jQuery.type并不能在舊的IE中檢測出undefined的正確性。想要獲得純凈的undefined可以使用 void 0

另外,對于DOM,BOM對象在舊的IE中使用Objec.prototype.toString檢測出來的值均為 “[object Object]”

但是在chrome下的結果卻完全不同(chrome可以檢測出真實類型)

了解一下jQuery檢測特殊類型

isWindow: function( obj ) {//ECMA規定window為全局對象global,且global.window === global return obj != null && obj == obj.window;},isPlainObject: function( obj ) { var key; if ( !obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) {  return false; } try {//判斷它最近的原形對象是否含有isPrototypeOf屬性  if ( obj.constructor &&   !hasOwn.call(obj, "constructor") &&   !hasOwn.call(obj.constructor.prototype, "isPrototypeOf") ) {   return false;  } } catch ( e ) {  return false; } if ( support.ownLast ) {  for ( key in obj ) {   return hasOwn.call( obj, key );  } }

mass Framework相對jQuery中改善的地方

var class2type = {//將可能出現的類型都映射在了class2type對象中,從而減少isXXX函數  "[object HTMLDocument]": "Document",  "[object HTMLCollection]": "NodeList",  "[object StaticNodeList]": "NodeList",  "[object DOMWindow]": "Window",  "[object global]": "Window",  "null": "Null",  "NaN": "NaN",  "undefined": "Undefined" };type: function(obj, str) {   var result = class2type[(obj == null || obj !== obj) ? obj : serialize.call(obj)] || obj.nodeName || "#"; //serialize == class2type.toString   if (result.charAt(0) === "#") { //兼容舊式瀏覽器與處理個別情況,如window.opera    //利用IE678 window == document為true,document == window竟然為false的神奇特性    if (obj == obj.document && obj.document != obj) {//對DOM,BOM對象采用nodeType(單一)和item(節點集合)進行判斷     result = "Window"; //返回構造器名字    } else if (obj.nodeType === 9) {     result = "Document"; //返回構造器名字    } else if (obj.callee) {     result = "Arguments"; //返回構造器名字    } else if (isFinite(obj.length) && obj.item) {     result = "NodeList"; //處理節點集合    } else {     result = serialize.call(obj).slice(8, -1);    }   }   if (str) {    return str === result;   }   return result;  }

類數組

類數組是一類特殊的數據類型存在,他們本身類似Array但是又不能使用Array的方法,他們有一個明顯的特點就是含有length屬性,而且 鍵值是以整數有序的排列的。這樣的數組可以通過 Array.slice() 這樣的方法轉換成真正的數組,從而使用Array提供的方法。

常見類數組:arguments,document.forms,document.getElementsByClassName(等一些列節點集合NodeList,HTMLCollection),或者是一些特殊對象,如下所示:

var arrayLike={    0:"a",    1:"b",    2:"c",    length:3 }

通常情況下通過Array.slice.call既可以轉換類數組,但是舊IE的HTMLCollection,NodeList不是Object 的子類,不能使用該方法,這時候需要構建一個空數組,然后將遍歷節點push就如空數組中,返回新生成的數組即可,同時要區別出window 和 string對象,因為這類的對象同樣含有length>=0(length不可被修改),但是不是類數組。

jQuery如何處理類數組的

makeArray: function( arr, results ) { var ret = results || []; if ( arr != null ) {  if ( isArraylike( Object(arr) ) ) {   jQuery.merge( ret,    typeof arr === "string" ?    [ arr ] : arr   );  //jQuery.merge 合并數組 ,若是字符串則封裝成數組河濱,不是則世界合并  } else {   push.call( ret, arr );  } } return ret;}

Ext.js是如何處理類數組的

toArray: function(iterable, start, end) {    if (!iterable || !iterable.length) {     return [];  //非類數組類型直接返回[]    }    if (typeof iterable === 'string') {     iterable = iterable.split('');  //分解字符串    }    if (supportsSliceOnNodeList) {     return slice.call(iterable, start || 0, end || iterable.length); //對于NodeList支持    }    var array = [],     i;    start = start || 0;    end = end ? ((end < 0) ? iterable.length + end : end) : iterable.length;    for (i = start; i < end; i++) {     array.push(iterable[i]);    }    return array;   }

mass Framework.js是如何處理類數組的

slice: W3C ? function(nodes, start, end) { //var W3C = DOC.dispatchEvent; IE9開始支持W3C的事件模型 return factorys.slice.call(nodes, start, end);} : function(nodes, start, end) { var ret = [],   n = nodes.length; if (end === void 0 || typeof end === "number" && isFinite(end)) {  start = parseInt(start, 10) || 0;  end = end == void 0 ? n : parseInt(end, 10);  if (start < 0) {   start += n;  }  if (end > n) {   end = n;  }  if (end < 0) {   end += n;  }  for (var i = start; i < end; ++i) {   ret[i - start] = nodes[i];  } } return ret;

以上就是本文的全部內容,希望對大家的學習有所幫助

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美在线第一页| 亚洲成人久久久| 91精品国产乱码久久久久久蜜臀| 亚洲一区二区久久久| 亚洲成人av资源网| 日韩av中文在线| 亚洲成人国产精品| 亚洲国内高清视频| 日韩视频第一页| 亚洲国产97在线精品一区| 国产综合在线观看视频| 国产精品久久久久久久久久99| 欧美性猛交xxxx免费看漫画| 久热精品视频在线| 亚洲视屏在线播放| 狠狠色狠色综合曰曰| 91大神在线播放精品| 中文字幕av一区二区三区谷原希美| 亚洲三级免费看| 亚洲免费视频在线观看| 国产精品日日做人人爱| 国产一区二区色| 亚洲伊人成综合成人网| 亚洲а∨天堂久久精品喷水| 国产91网红主播在线观看| 国产精品亚洲美女av网站| 国产视频精品xxxx| 日韩精品中文字| 国产小视频91| 久久九九免费视频| 国产精品96久久久久久| 91精品国产自产在线观看永久| 欧美日本亚洲视频| 欧美性猛交xxxx富婆| 亚洲自拍另类欧美丝袜| 97精品伊人久久久大香线蕉| 日韩第一页在线| 欧美精品少妇videofree| 欧美性猛交99久久久久99按摩| 91久久国产婷婷一区二区| 久久久久一本一区二区青青蜜月| 91精品国产综合久久香蕉922| 在线看日韩av| 一区二区三区视频免费在线观看| 色妞久久福利网| 91成人免费观看网站| 欧美一级成年大片在线观看| 欧美成人午夜视频| 这里只有视频精品| 亚洲欧美综合区自拍另类| 精品无码久久久久久国产| 欧美激情xxxxx| 日本精品视频在线| 中文精品99久久国产香蕉| 91久久精品美女高潮| 国产91色在线播放| 国产亚洲综合久久| 在线观看91久久久久久| 2024亚洲男人天堂| 日韩久久免费电影| 国产在线久久久| 国产午夜精品一区理论片飘花| 日韩av在线最新| 国产免费一区二区三区在线观看| 97超碰色婷婷| 亚洲国产97在线精品一区| 亚洲一区二区三区777| 国产欧美一区二区三区久久| 国产精品一香蕉国产线看观看| 国模精品一区二区三区色天香| 91精品久久久久久久久中文字幕| 欧美激情伊人电影| 亚洲精品福利资源站| 亚洲视频国产视频| 日韩中文字幕网| 亚洲日本成人女熟在线观看| 久久久91精品国产一区不卡| 国产成人精品久久亚洲高清不卡| 国语自产精品视频在免费| www.亚洲成人| 欧美日韩国产精品一区二区三区四区| 亚洲国产精品电影在线观看| 欧美在线亚洲一区| 欧美刺激性大交免费视频| 91精品国产乱码久久久久久久久| 亚洲最新av在线| 国产一区二区三区18| 青草成人免费视频| 国产精品极品尤物在线观看| 欧美一级免费看| 91在线中文字幕| 欧美亚州一区二区三区| 欧美人与物videos| 欧美激情国产日韩精品一区18| 成人福利在线观看| 国产一区二区欧美日韩| 亚洲欧美日韩图片| 夜夜嗨av一区二区三区四区| 亚洲视频axxx| 欧美大片欧美激情性色a∨久久| 国产精品情侣自拍| 国产精品69精品一区二区三区| 69视频在线播放| 国产成人一区二区三区| 麻豆国产va免费精品高清在线| 久久久精品网站| 日韩欧美在线视频日韩欧美在线视频| 国产剧情日韩欧美| 国产精品福利片| 欧美性xxxx极品hd满灌| 成人午夜两性视频| 国产在线视频欧美| 日韩精品亚洲元码| 久久精品91久久香蕉加勒比| 蜜臀久久99精品久久久久久宅男| 欧美日韩激情美女| 青青草成人在线| 日韩av在线影院| 亚洲国产97在线精品一区| 国产精品第七十二页| 中文字幕精品在线视频| 久久综合久久八八| 亚洲va码欧洲m码| 国产v综合ⅴ日韩v欧美大片| 国产精品高清在线观看| 国模精品系列视频| 7777精品久久久久久| 欧美壮男野外gaytube| 中文字幕久热精品在线视频| 日韩欧美一区二区在线| 九九视频这里只有精品| 欧美贵妇videos办公室| 色哟哟入口国产精品| 中文字幕精品在线视频| 欧美久久精品午夜青青大伊人| 91av视频在线免费观看| 国内成人精品一区| 91色在线视频| 久久在线免费视频| 欧美激情国产高清| 亚洲精品有码在线| 国产精品美女视频网站| 亚洲区一区二区| 久久99国产精品久久久久久久久| 亚洲а∨天堂久久精品9966| 68精品国产免费久久久久久婷婷| 在线观看精品自拍私拍| 最近2019年好看中文字幕视频| 欧美日韩裸体免费视频| 欧美激情精品久久久久久| 超碰日本道色综合久久综合| 国产区亚洲区欧美区| 国产精品美女无圣光视频| 色综合久久88色综合天天看泰| 亚州国产精品久久久| 精品视频久久久| 欧美裸体xxxxx| 日韩精品丝袜在线| 欧美日韩在线视频首页| 亚洲va国产va天堂va久久| 国产精品入口福利| 成人国产精品色哟哟| 中文字幕国产亚洲2019| 国产成人亚洲综合青青|