這個方法起先用在 IE ,用來確定 DOM Node 是否包含在另一個 DOM Element 中。

當嘗試優化 CSS 選擇器遍歷(像:“#id1 #id2”),這個方法很有用。你可以通過 getElementById 得到元素,然 " /> 欧美一级在线全免费,2020精品极品国产色在线观看,性xxxx18免费观看

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript比較文檔位置

1、DOMElement.contains(DOMNode)

這個方法起先用在 IE ,用來確定 DOM Node 是否包含在另一個 DOM Element 中。

當嘗試優化 CSS 選擇器遍歷(像:“#id1 #id2”),這個方法很有用。你可以通過 getElementById 得到元素,然后使用 .contains() 確定 #id1 實際上是否包含 #id2。

注意點:如果 DOM Node 和 DOM Element 相一致,.contains() 將返回 true ,雖然,一個元素不能包含自己。

這里有一個簡單的執行包裝,可以運行在:InterNET Explorer, Firefox, Opera, and Safari。


function contains(a, b) {
    return a.contains ? a != b && a.contains(b) : !!(a.compareDocumentPosition(arg) & 16);
}
2、NodeA.compareDocumentPosition(NodeB) 

這個方法是 DOM Level 3 specification 的一部分,允許你確定 2 個 DOM Node 之間的相互位置。這個方法比 .contains() 強大。這個方法的一個可能應用是排序 DOM Node 成一個詳細精確的順序。

使用這個方法你可以確定關于一個元素位置的一連串的信息。所有的這些信息將返回一個比特碼(Bit,比特,亦稱二進制位)。

對于那些,人們知之甚少。比特碼是將多重數據存儲為一個簡單的數字(譯者注:0 或 1)。你最終打開 / 關閉個別數目(譯者注:打開/關閉對應 0 /1),將給你一個最終的結果。

這里是從 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 瀏覽器的私有使用 

現在,這意味著一個可能的結果類似于:


<div id="a">
    <div id="b"></div>
</div>
<script>
    alert( document.getElementById("a").compareDocumentPosition(document.getElementById("b")) == 20);
</script>
一旦一個節點 A 包含另一個節點 B,包含 B(+16) 且在 B 之前(+4),則最后的結果是數字 20 。如果你查看比特發生的變化,將增加你的理解。

000100 (4) + 010000 (16) = 010100 (20)

這個,毫無疑問,有助于理解單個最混亂的 DOM API 方法。當然,他的價值當之無愧的。

現在,DOMNode.compareDocumentPosition 在 Firefox 和 Opera 中是可用的。然而,有一些技巧,我們可以用來在 IE 中執行他。


// Compare Position - MIT Licensed, John Resig
function comparePosition(a, b){
    return a.compareDocumentPosition ?
    a.compareDocumentPosition(b) :
    a.contains ?
        ( a != b && a.contains(b) && 16 ) +
        ( a != b && b.contains(a) && 8 ) +
        ( a.sourceIndex >= 0 && b.sourceIndex >= 0 ?
            (a.sourceIndex < b.sourceIndex && 4 ) +
            (a.sourceIndex > b.sourceIndex && 2 ) :
            1 ) :
        0;
}
IE 提供給我們一些可以使用的方法和屬性。開始,使用 .contains() 方法(如我們前面所討論的),以便給我們包含(+16)或者被包含(+8)的結果。IE 還有一個 .sourceIndex 屬性在所有的 DOM Element 對應著元素在文檔中的位置,例如:document.documentElement.sourceIndex == 0。因為我們有這個信息,我們可以完成兩個 compareDocumentPosition 難題:在前面(+2)和在后面(+4)。另外,如果一個元素不在當前的文檔,.sourceIndex 將等于 -1,這個給我們另外一個回答(+1)。最后,通過這個過程的推斷,我們可以確定如果一個元素等于他本身,返回一個空的比特碼(+0)。

這個函數可以在 InterNET Explorer、Firefox 和 Opera 中運行。但在 Safari 中卻有殘缺功能(因為他只有 contains() 方法,而沒有 .sourceIndex 屬性。我們只能得到 包含(+16),被包含(+8),其他的所有結果都將返回(+1)代表一個斷開)。

PPK 提供了一個關于通過創建一個 getElementsByTagNames 方法使新功能可以被使用的很棒的例子。讓我們改編他到我們的新方法中:


// Original by PPK quirksmode.org
function getElementsByTagNames(list, elem) {
        elem = elem || document;          

        var tagNames = list.split(','), results = [];          

        for ( var i = 0; i < tagNames.length; i++ ) {
                var tags = elem.getElementsByTagName( tagNames[i] );
                for ( var j = 0; j < tags.length; j++ )
                        results.push( tags[j] );
        }          

        return results.sort(function(a, b){
                return 3 - (comparePosition(a, b) & 6);
        });
}
我們現在可以使用他來按次序構建一個站點的目錄:


getElementsByTagNames("h1, h2, h3");
雖然 Firefox 和 Opera 都采取了一些主動落實這一方法。我依然期待看到更多的瀏覽器進入,以幫助向前推動。

JavaScript技術javascript比較文檔位置,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产日韩欧美综合一区二区三区 | 美女黄色免费网站 | 中文字幕一区二区在线播放 | 色视频哟女在线观看 | 精品极品三级久久久久 | 一级毛片成人免费看免费不卡 | 米奇777超碰欧美日韩亚洲 | 综合精品视频 | 一级特黄欧美 | 色婷婷视频在线观看 | 亚洲一区二区在线免费观看 | 国产青草视频在线观看 | 成人精品综合免费视频 | 99视频在线观看视频一区 | 国产成人99久久亚洲综合精品 | 国产精品福利午夜一级毛片 | 国产精品黑色丝袜的老师 | 亚洲欧洲日韩国产一区二区三区 | 四虎永久免费网站免费观看 | 91麻豆久久 | 黄色影院7755 | 国产精选视频 | 大色网小色网 | 国产精品久久久久久一区二区三区 | 久久精品亚洲精品国产色婷 | 久久综合图片 | 国产成人精品午夜在线播放 | 91久久精品一区二区三区 | 国产亚洲精品激情都市 | 国产精品猎奇系列在线观看 | 国产一区二区精品久久凹凸 | 日本大片免a费观看视频+播放器 | 一区二区三区不卡视频 | 亚洲第一免费网站 | 加勒比一本 | 国产91激情对白露脸全程 | 伊人第四色 | 成人午夜视频在线观看 | 亚洲国产精品久久 | 好吊妞视频免费观看va | 久久全国免费久久青青小草 |