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

首頁 > 編程 > JavaScript > 正文

通過jQuery學習js類型判斷的技巧

2019-11-19 11:27:59
字體:
來源:轉載
供稿:網友

1. isFunction中typeof的不靠譜

源碼:

var isFunction = function isFunction( obj ) {// Support: Chrome <=57, Firefox <=52// In some browsers, typeof returns "function" for HTML <object> elements// (i.e., `typeof document.createElement( "object" ) === "function"`).// We don't want to classify *any* DOM node as a function.return typeof obj === "function" && typeof obj.nodeType !== "number";};

typeof 是為了區分數據類型,下面是MDN中總結的typeof中所有存在的值

問題一:我們都知道typeof null 出來的結果是‘object',可這是為啥呢?MDN給出了答案 :因為null是空指針,而空指針在大多數平臺中使用0x00表示,而js在實現初期通過用 0 作為對象的標簽,所以對null也被判斷為object。

問題二:既然typeof能夠判斷出function,為何jquery額外判斷 typeof obj.nodeType !== "number" 呢?

long long ago,在那些古老的瀏覽器中:

1. typeof document.body.childNodes // function 這在古老的 safari 3 中會出現

2.typeof document.createElement("object") // function 同理還有 'embed' 'applet' , 在古老的firefox中會出現,目前新版本不會存在

3.typeof /s/ // function 這種情況會在古老瀏覽器中出現,目前都會被判定為 object

通過以上問題我們可以看出,通過typeof判斷數據類型在古老的瀏覽器中是極為不靠譜的,所以在jquery的isFunction的判斷中額外添加了判斷 檢測對象是否為dom 對象2.靠譜的數據類型判斷

源碼:

var class2type = {};var toString = class2type.toString;// Populate the class2type map,這里并沒有undefinedjQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ),function( i, name ) {class2type[ "[object " + name + "]" ] = name.toLowerCase();} );function toType( obj ) {if ( obj == null ) {return obj + "";}// Support: Android <=2.3 only (functionish RegExp)return typeof obj === "object" || typeof obj === "function" ?class2type[ toString.call( obj ) ] || "object" :typeof obj;}

在代碼中jquery做了這幾件事:

1.jquery先提取出toString 這個方法

2.將寫好的類型字符串分割并存入class2type中,class2type 數據結構如下:

3.定義toType方法,因為 toString(null)會得出‘ [object Undefined]'的結果,所以需要把null單獨判斷,注意null是沒有toString這個方法的,所以通過 obj+''這個方式得到 'null'

4.在單獨判斷null后是一個三元運算符:等價于

1 if(typeof obj === "object" || typeof obj === "function"){2 // 因為上文提到存在typeof /s/ 為 function的情況,所以需要toString詳細判斷3 // 對于判斷不出的數據類型默認為object4 retrun class2type[ toString.call( obj ) ] || "object";5 } else {6 // 通過上面typeof對類型判斷的表格,判斷非object function還是很可靠的,所以直接用原生方法7 return typeof obj;8 }

結論: 通過用toString方法可以判斷出Boolean、Number、 String、 Function、 Array、 Date、 RegExp、 Object、 Error、 Symbol、undefined 這些數據類型,但是并不能判斷出null,所以要綜合判斷,就醬

除此之外jquery還額外判斷了當前對象是否為window,只用了如下的方法:

var isWindow = function isWindow( obj ) {return obj != null && obj === obj.window;};

前方的obj!=null 是為了防止開發人員在調用函數 isWindow時傳入null 、undefined的時候報Uncaught TypeError: Cannot read property 'window' of null/undefined的錯誤。

還有isArrayLike,判斷當前對象是不是類數組對象,類數組對象是什么,建議大家百度一下

function isArrayLike( obj ) {// Support: real iOS 8.2 only (not reproducible in simulator)// `in` check used to prevent JIT error (gh-2145)// hasOwn isn't used here due to false negatives// regarding Nodelist length in IEvar length = !!obj && "length" in obj && obj.length,type = toType( obj );if ( isFunction( obj ) || isWindow( obj ) ) {return false;}return type === "array" || length === 0 ||typeof length === "number" && length > 0 && ( length - 1 ) in obj;}

首先判斷obj中是否有length屬性并取出length

然后排除obj是否是window 及 function

最后取值條件:1.是否是array(類數組對象集合當然包括數組) 2.存在length屬性但length是0 3.判定length是數字且大于零,并在obj對象中存在length-1屬性

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品福利视频| 亚洲国产成人爱av在线播放| 欧美裸身视频免费观看| 97色在线视频观看| 国内免费精品永久在线视频| 国产精品免费小视频| 91精品国产综合久久男男| 亚洲精品在线不卡| 久久久久久久久久久av| 欧美日韩国产二区| 成人免费xxxxx在线观看| 国产香蕉一区二区三区在线视频| 亚洲精品久久久久国产| 精品亚洲一区二区三区在线播放| 在线观看日韩欧美| 亚洲福利视频网站| 亚洲自拍偷拍色图| 国产精品福利在线| 亚洲区bt下载| 国产精品成人品| 日本精品一区二区三区在线| 亚洲一区国产精品| 欧美日韩国产中字| 久久久亚洲影院你懂的| 精品国产一区二区三区四区在线观看| 亚洲国产91精品在线观看| 精品久久香蕉国产线看观看亚洲| 欧美国产日韩xxxxx| 91精品国产色综合久久不卡98口| 亚洲91av视频| 亚洲福利在线看| 国产成人福利夜色影视| 国产小视频91| 7m精品福利视频导航| 亚洲精品午夜精品| 黄色精品在线看| 国产精品视频在线播放| 91国偷自产一区二区三区的观看方式| 久久伊人精品天天| 国产在线视频2019最新视频| 久久人人爽亚洲精品天堂| www.久久久久久.com| 国产精品久久久久久久午夜| 欧美精品videossex88| 综合欧美国产视频二区| 亚洲第一色中文字幕| 色哟哟亚洲精品一区二区| 亚洲欧美日韩中文视频| 一区二区欧美日韩视频| 亚洲精品自产拍| 2019最新中文字幕| 国产日产亚洲精品| 欧美激情亚洲精品| 亚洲第一区在线观看| 国产精品视频一区二区高潮| 亚洲精品中文字| xxx成人少妇69| 韩国国内大量揄拍精品视频| 欧美一区二区大胆人体摄影专业网站| 久久视频中文字幕| 亚洲欧洲av一区二区| 欧美日韩国产第一页| 日韩精品在线免费观看| 欧美黄色免费网站| 亚洲视频欧美视频| 91国自产精品中文字幕亚洲| 国产丝袜一区视频在线观看| 热99精品里视频精品| 亚洲丝袜一区在线| 欧美激情欧美激情在线五月| 国产精品日韩精品| 国产91精品高潮白浆喷水| 美女性感视频久久久| 亚洲天堂视频在线观看| 欧美午夜精品久久久久久浪潮| 欧洲精品毛片网站| 日本19禁啪啪免费观看www| 91国产在线精品| 欧美激情在线狂野欧美精品| 国产一区二区黄| 91av免费观看91av精品在线| 色综合视频一区中文字幕| 中文综合在线观看| 日韩中文有码在线视频| 精品日韩中文字幕| www.国产精品一二区| 国产精品丝袜白浆摸在线| 日本精品一区二区三区在线播放视频| 永久免费看mv网站入口亚洲| 欧美日韩中国免费专区在线看| 久久久久久久久久国产精品| 国产精品成熟老女人| 国产精品视频精品| 日韩亚洲在线观看| 色琪琪综合男人的天堂aⅴ视频| 久久久久久久久久久人体| 亚洲嫩模很污视频| 欧美中文在线观看| 国产精品91久久久| 国产91在线播放| 激情亚洲一区二区三区四区| 亚洲激情自拍图| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲3p在线观看| 国产自产女人91一区在线观看| 欧美大尺度电影在线观看| 国产精品久久久久久超碰| 国产精品成人一区| 亚洲xxxxx电影| 国产噜噜噜噜噜久久久久久久久| 久久综合伊人77777| 欧美日韩在线观看视频| 精品magnet| 成人xxxx视频| 国产精品久久久久久婷婷天堂| 亚洲视频日韩精品| 91av视频在线免费观看| 亚洲三级黄色在线观看| 亚洲自拍偷拍视频| 日韩电影视频免费| 国产精品自在线| 精品久久久视频| 亚洲国产一区自拍| 91香蕉国产在线观看| 日韩精品999| 亚洲老头老太hd| 国产女同一区二区| 日韩av最新在线| 日韩av免费观影| 亚洲精品videossex少妇| 国产精品久久久久久久电影| 久久五月天综合| 国产精品久久久久99| 亚洲电影天堂av| 精品视频偷偷看在线观看| 91免费在线视频网站| 国产精品亚洲网站| 在线观看国产成人av片| 午夜精品久久久久久久久久久久| 久久视频在线看| 日韩经典中文字幕| 欧美午夜电影在线| 国产成人激情视频| 91视频国产高清| 久久久久久91香蕉国产| 国产ts一区二区| 日韩av免费看网站| 97在线视频一区| 精品久久国产精品| 国产97色在线|日韩| 精品在线欧美视频| 美女黄色丝袜一区| 日韩在线视频观看正片免费网站| 欧美一区在线直播| 亚洲经典中文字幕| 91av国产在线| 亚洲国产欧美久久| 蜜臀久久99精品久久久久久宅男| 亚洲天堂av在线免费观看| 日韩av黄色在线观看| 国产不卡一区二区在线播放| 国产精品午夜国产小视频| 欧美xxxx做受欧美| 国语自产精品视频在线看|