中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術文檔 > 網頁制作 > 比較文檔位置
客齊集社區(qū)頭像顯示效果 回到列表 火星人的耳機
 比較文檔位置

作者:blank 時間: 2008-04-02 文檔類型:翻譯 來自:藍色理想

一個很棒的 blog 文章,是 PPK 兩年前寫的,文章中解釋了 contains() 和 compareDocumentPosition() 方法運行在他們各自的瀏覽器上。從那起,我已經對這些方法做了大量的研究,并且已經在很多場合使用他們。在很多任務中,他們被證明是非常有用的(特別關于結構的抽象 DOM 選擇器)。

1、DOMElement.contains(DOMNode)

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

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

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

這里有一個簡單的執(zhí)行包裝,可以運行在: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,比特,亦稱二進制位)。

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

這里是從 NodeA.compareDocumentPosition(NodeB) 返回的結果,包含你可以得到的信息。

Bits          Number        Meaning
000000         0              元素一致
000001         1              節(jié)點在不同的文檔(或者一個在文檔之外)
000010         2              節(jié)點 B 在節(jié)點 A 之前
000100         4              節(jié)點 A 在節(jié)點 B 之前
001000         8              節(jié)點 B 包含節(jié)點 A
010000         16             節(jié)點 A 包含節(jié)點 B
100000         32             瀏覽器的私有使用

現(xiàn)在,這意味著一個可能的結果類似于:

<div id="a">
 <div id="b"></div>
</div>
<script>
 alert( document.getElementById("a").compareDocumentPosition(document.getElementById("b")) == 20);
</script>

一旦一個節(jié)點 A 包含另一個節(jié)點 B,包含 B(+16) 且在 B 之前(+4),則最后的結果是數(shù)字 20 。如果你查看比特發(fā)生的變化,將增加你的理解。

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

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

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

// 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)。

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

PPK 提供了一個關于通過創(chuàng)建一個 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);
        });
}

我們現(xiàn)在可以使用他來按次序構建一個站點的目錄:

getElementsByTagNames("h1, h2, h3");

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

翻譯自:《Comparing Document Position

本文鏈接:http://www.95time.cn/tech/web/2008/5608.asp 

出處:藍色理想
責任編輯:bluehearts

◎進入論壇網頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

相關文章 更多相關鏈接
客齊集社區(qū)頭像顯示效果
理解JavaScript中的事件
一個封裝了的選項卡效果js
JS的IE和FF兼容性問題匯總
Javascript風格要素 Ⅱ
作者文章 更多作者文章
HTML5中 b 和 i 標簽將語義化
函數(shù)般調用正則
z-index在IE中的迷惑
42個值得閱讀的設計/技術雜志
由淺入深漫談margin屬性
關鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權申明:除部分特別聲明不要轉載,或者授權我站獨家播發(fā)的文章外,大家可以自由轉載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權歸我站和作者共有。

轉載要求:轉載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(lián)系,版權歸原作者所有,文章若有侵犯作者版權,請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內容無關的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網上道德,遵守中華人民共和國的各項有關法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權保留或刪除其管轄評論中的任意內容
·您在本站發(fā)表的作品,本站有權在網站內轉載或引用
·參與本評論即表明您已經閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內容
網站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網站UI 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內核詳解與實踐
作品集 更多內容

雜⑦雜⑧ Gold NORMANA V2