天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript DOM 學習第九章 選取范圍的介紹

雖然我們會講解用程序創建范圍對象,但是我們把精力主要集中在如何將用戶的選取范圍轉換成為W3C 范圍或者微軟的文檔范圍對象。

 

什么是范圍

范圍是指HTML文檔中的任意一部分內容。一個范圍的開始和結束點都可以是隨意的,甚至是相同的(一個空范圍)。最常見的范圍就是用戶選取的文本。當用戶在頁面上選取了一部分,你就可以他的選取部分轉換為范圍對象。然而,你也可以讓程序自動選擇范圍。

讓我們以下面的代碼為例。假設用戶選擇了下面的文字:

<h4 id="entry1196"><a

class="external">Call for a Blogger's Code of Conduct</a></h4>

<p>Tim O'Reilly calls for a Blogger Code of Conduct. His proposals are:</p>

<ol>
<li>Take responsibility not just for your own words, but for the
comments you allow on your blog.</li>
<li>Label your tolerance level for abusive comments.</li>
<li>Consider eliminating anonymous comments.</li>
</ol>

你可以將用戶選擇轉換為一個包含用戶選擇范圍的文本的范圍對象(后面講)。根據范圍對象,你能找到開始和結束的范圍點。如果你愿意你可以刪除它拷貝它或者用其他文本代替,甚至用HTML代碼來代替。

這是范圍對象最簡單的例子了,因為他只包含文本。下面我們來看一個復雜的例子:

<h4 id="entry1196"><a

class="external">Call for a Blogger's Code of Conduct</a></h4>

<p>Tim O'Reilly calls for a Blogger Code of Conduct. His proposals are:</p>

<ol>
<li>Take responsibility not just for your own words, but for the
comments you allow on your blog.</li>
<li>Label
your tolerance level for abusive comments.</li>
<li>Consider eliminating anonymous comments.</li>
</ol>

另外一個范圍對象被創建了,而且還包含HTML。問題在于用戶的選擇范圍跨越了幾個元素。去掉其他的內容,就剩下:

calls for a Blogger Code of Conduct. His proposals are:</p>

<ol>
<li>Take responsibility not just for your own words, but for the
comments you allow on your blog.</li>
<li>Label your toleran

這是一段不完整的HTML。幸好所有的瀏覽器都會轉化一下:

<p>calls for a Blogger Code of Conduct. His proposals are:</p>

<ol>
<li>Take responsibility not just for your own words, but for the
comments you allow on your blog.</li>
<li>Label your toleran</li></ol>

正如你所看到的,瀏覽器會添加最少的元素讓這段HTML完整,如果你復制的話,那么這些添加的東西也會被復制。

 

瀏覽器兼容性一覽

在我們繼續之前,有必要看看瀏覽器的兼容性。主要問題在于這里有不下3個范圍對象的類型,你必須都有所了解才行。

Module

Explorer 6/7

Firefox 2Safari 1.3Opera 9
W3C Rangenoyesyesyes
Mozilla Selectionnoyesincompleteyes
Microsoft Text Rangeyesnonoincomplete

 

 

訪問用戶選區

要處理用戶的選擇就必須先訪問到用戶的選區。這會立馬又一個代碼分支:IE使用微軟的方法,其他瀏覽器使用Mozilla的方法:
復制代碼 代碼如下:
var userSelection;
if (window.getSelection) {
    userSelection = window.getSelection();
}
else if (document.selection) { // should come last; Opera!
    userSelection = document.selection.createRange();
}

在Mozilla,Safari,Opera里面現在userSelection是一個選擇對象(selection object),在IE中是一個文本范圍對象(text range object)。這個區別在后面的代碼中依然有效:IE的文本范圍對象和W3C的范圍對象以及Mozilla的選擇對象有根本的不同,每一部分的代碼都需要另一部分的補充。

要注意分支的順序:Mozilla Selection一定要在前。因為Opera兩種都支持,如果你用window.getSelection()讀取用戶的選區,Opera就會創建一個選擇對象,可是你用document.selection的時候他也會創建一個文本范圍對象。

雖然Opera支持Mozilla和W3C模式很不錯,但是支持IE確是有毛病,這樣就不得不把window.getSelection放在前面檢測。

userSelection的內容
現在userSelection既是一個Mozilla的選擇對象又是IE的文本范圍對象。這樣他就可以使用所有的方法和屬性了。

然后,Mozilla的選擇對象userSelection里面保存的用戶選擇的文本(而不是HTML)。這樣寫:

復制代碼 代碼如下:alert(userSelection)
就會產生:

calls for a Blogger Code of Conduct. His proposals are: Take responsibilitynot just for your own words, but for the comments you allow on your blog.Label your toleran如果想在微軟的文本范圍對象中得到相同的內容你就要使用:

var selectedText = userSelection;if (userSelection.text)    selectedText = userSelection.text;現在selectedText就包含了用戶選擇的文本。如果你覺得這樣的信息足夠的話,那么就開始準備后面的工作吧。

從選擇對象創建范圍對象
很多時候,你想處理的是代表用戶選擇范圍的范圍對象(range object)。在微軟模式中條件已經具備:userSelection就是一個文本范圍。在兼容W3C的瀏覽器中userSelection依然只是一個選擇對象,是時候創建一個與選擇對象內容相同的范圍對象了。

按照下面這樣:
復制代碼 代碼如下:
var rangeObject = getRangeObject(userSelection);
function getRangeObject(selectionObject) {
    if (selectionObject.getRangeAt)
        return selectionObject.getRangeAt(0);
    else { // Safari!
        var range = document.createRange();
        range.setStart(selectionObject.anchorNode,selectionObject.anchorOffset);
        range.setEnd(selectionObject.focusNode,selectionObject.focusOffset);
        return range;
    }
}

理想情況下,我們通過選擇對象的getRangeAt()來訪問W3C范圍對象。這個方法會在給定的位置返回一個范圍對象:就像平常一樣第一個范圍對象的編號是0。(getRangeAt()已經設計好如果有多處選擇的情況下怎么辦。在那種情況下你的代碼也很簡單)

自從創建一個范圍

不幸的是Safari1.3不支持getRangeAt()。因此我們需要創建一個跟用戶選擇一樣的范圍對象。這是一個很好的練習機會,可以讓你知道如何創建自己的范圍對象。

很明顯的從創建一個對象開始:

var range = document.createRange();

現在我們已經有了一個空對象。為了把他插入到文檔里面去我們需要使用setStart()函數和setEnd()函數。

這兩個方法需要兩個參數:

1、在哪個DOM節點上開始或者結束的?

2、從哪個文本偏移上開始或者結束的?文本偏移就是指范圍對象的第一個或者最后一個字符的位置。

讓我們再來看一遍第二個例子:

	
class="external">Call for a Blogger's Code of Conduct</a></h4>

<p>Tim O'Reilly calls for a Blogger Code of Conduct. His proposals are:</p>

<ol>
<li>Take responsibility not just for your own words, but for the
comments you allow on your blog.</li>
<li>Label
your tolerance level for abusive comments.</li>
<li>Consider eliminating anonymous comments.</li>
</ol>

范圍從<p>節點開始,并且文字偏移量是13,因為第14個字符已經是包含在范圍里面的了(和通常一樣,編號從0開始的)。

范圍從<li>結束,偏移量是17,因為第18個字符時范圍內的最后一個字符了。

如何創建這個范圍對象:
復制代碼 代碼如下:
var startPar = [the p node];
var endLi = [the second li node];
range.setStart(startPar,13);
range.setEnd(endLi,17);

(注意現在創建的范圍對用戶不可見,只在瀏覽器的內部)

現在我們已經創建了一個范圍,我們也可以讀出他的開始和結束點。startContainer和startOffset決定了范圍的開始位置,同樣的endContainer和endOffset決定了結束位置。

讀取選區的開始和結束位置
不幸的是,你并不知道用戶選擇了頁面哪個部分。所以你需要先讀出用戶選擇的開始和結束的位置:這個必須在選擇對象(selection object)里面完成,因為這時候還沒有范圍對象(range object)。

我們剛剛看到每一個范圍對象都有標明他開始和結束位置的四個屬性。選擇對象也有相似的。當然是另外的名字:anchorNode/anchorOffset代表開始位置,focusNode/focusOffset代表結束位置。

所以讀出了選擇對象的開始和結束位置之后我們就能創建范圍對象了:

復制代碼 代碼如下:
range.setStart(selectionObject.anchorNode,selectionObject.anchorOffset);
range.setEnd(selectionObject.focusNode,selectionObject.focusOffset);

待續
現在我們有了范圍對象和微軟的文本范圍對象。以后我們會講解如何使用它們,并且解決不兼容的問題。

翻譯地址:http://www.quirksmode.org/dom/range_intro.html

轉載請保留以下信息
作者:北玉(tw:@rehawk)

JavaScript技術JavaScript DOM 學習第九章 選取范圍的介紹,轉載需保留來源!

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

主站蜘蛛池模板: 男人有噶坏 | 性刺激欧美三级在线现看中文 | www.欧美与曽交性video | 亚洲 欧洲 国产 日产 综合 | 中文字幕无线观看不卡网站 | 成人网18免费韩国 | 日韩a在线看免费观看视频 日韩a视频在线观看 | 日日噜噜大屁股熟妇 | 成年色黄APP下载 | 内射人妻无码色AV麻豆去百度搜 | 国产福利高清在线视频 | 久久强奷乱码老熟女 | 亚洲精品视频免费在线观看 | 69久久国产精品热88人妻 | 国产亚洲精品久久久闺蜜 | 野花社区WWW韩国日本 | 亚洲免费无码中文在线亚洲在 | 高清无码中文字幕影片 | 夜蒲团之5阳性之教 | a级销魂美女 | 欧美一区二区三区激情视频 | 欧美日韩高清一区 | 亚洲第一成年网站视频 | 无码国产欧美日韩精品 | 暖暖视频 免费 高清 日本8 | 亚洲 日韩 国产 中文视频 | 97精品伊人久久大香线蕉app | 亚洲精品在线免费 | 亚洲第一色网站 | 处 女 开 破小说 | 99久久亚洲综合精品 | 中国xxxxxz | 99久久免费精品国产免费 | av天堂电影网 | 国产精品久久人妻互换毛片 | 亚洲成色爱我久久 | 伊人青青青 | 麻豆区蜜芽区 | 免费高清毛片 | 神马影院午夜理论二 | 亚洲黄色免费在线观看 |