?jquery.contains(a,b) 判斷元素 a中是否包含 b 元素:
源碼:
contains = isNative(docElem.contains) || docElem.compareDocumentPosition ?function( a, b ) {var adown = a.nodeType === 9 ? a.documentElement : a,bup = b && b.parentNode;return a === bup || !!( bup && bup.nodeType === 1 && (adown.contains ?adown.contains( bup ) :a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16));} :function( a, b ) {if ( b ) {while ( (b = b.parentNode) ) {if ( b === a ) {return true;}}}return false;};
isNative:
rnative = /^[^{]+\{\s*\[native code/,function isNative( fn ) {return rnative.test( fn + "" ); }
重點解釋:
a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16
IE中是使用的 adown.contains( bup )來檢驗。
NodeA.compareDocumentPosition(NodeB) 返回的結果,包含你可以得到的信息。
Bits????????? Number??????? Meaning
000000???????? 0????????????? 元素一致
000001???????? 1????????????? 節點在不同的文檔(或者一個在文檔之外)
000010???????? 2????????????? 節點 B 在節點 A 之前
000100???????? 4????????????? 節點 A 在節點 B 之前
001000???????? 8????????????? 節點 B 包含節點 A
010000???????? 16???????????? 節點 A 包含節點 B
100000???????? 32???????????? 瀏覽器的私有使用
?
a.compareDocumentPosition( bup )的值只有是 16時,與 16進行 & 運算才為真,其它的值與 16 進行 & 運算 都是 0.