在一些業務場景,好比高亮文本、輸入編輯、等場景中須要對光標和選區進行操做時,可使用瀏覽器提供的 Selection
對象和 Range
對象來操做光標和選區。javascript
Selection
對象表示用戶選擇的選區或插入符號的當前位置,它可能橫跨多個元素。html
//獲取 Selection 對象 window.getSelection();
用戶可能從左到右(與文檔方向相同)選擇文本或從右到左(與文檔方向相反)選擇文本。 java
anchor
(錨點): 指向用戶開始選擇的地方。 focus
(焦點): 指向用戶結束選擇的地方。 node
若是你使用鼠標選擇文本的話,anchor
就指你按下鼠標鍵的地方,而 focus
就指你鬆開鼠標鍵的地方。anchor
和 focus
的概念不能與選區的起始位置和終止位置混淆,由於 anchor
可能在 focus
的前面,也可能在 focus
的後面,這取決於你選擇文本時鼠標移動的方向,也就是按下鼠標鍵和鬆開鼠標鍵的位置。瀏覽器
以下圖所示:app
anchor
)所在節點。anchorOffset:編輯器
anchorNode
是文本節點、註釋節點,返回錨點(anchor
)到該節點中第一個字的字符個數。anchorNode
是元素節點,返回錨點(anchor
)以前的同級節點總數。focus
)所在節點。focusOffset:函數
focusNode
是文本節點、註釋節點,返回焦點(focus
)到該節點中的第一個字的字符個數。focusNode
是元素節點,返回焦點(focus
)以前的同級節點總數。Boolean
值,若是爲 true
,能夠認爲當前沒有內容選中。Range
對象數量。type: 描述當前選區的類型,有如下三個值:spa
注意:
以上全部屬性都是只讀屬性。code
向選區(Selection
對象)中添加一個區域( Range
對象)。
range
: 一個區域對象
<p id="text">文本</p>
//添加一個選區 var text = document.querySelector("#text"); var selObj = window.getSelection(); var rangeObj = document.createRange(); rangeObj.selectNode(text); selObj.addRange(rangeObj);
收起當前選區到一個點。文檔不會發生改變。
parentNode
: 光標落在的目標節點 offset
: 可選,在目標節點內的偏移量
<div contenteditable="true" id="text">文本</div>
//收起選區到一個點,光標落在一個可編輯元素上 var text = document.querySelector("#text") window.getSelection().collapse(text,0);
取消當前選區,並把光標定位在原選區的最末尾處。
無
var selObj = window.getSelection(); selObj.collapseToEnd();
取消當前選區,並把光標定位在原選區的最開始處。
無
var selObj = window.getSelection(); selObj.collapseToStart();
判斷指定的節點是否包含在 Selection
對象中(便是否被選中)。
aNode
: 用於判斷是否包含在 Selection
對象中的節點。 aPartlyContained
:
當此參數爲 true
時,Selection
對象包含 aNode
的一部分或所有時,containsNode()
方法返回true
。
當此參數爲 false
(默認值)時,只有 Selection
對象徹底包含 aNode
時,containsNode()
方法才返回 true
。
<div id="text">文本</div>
var text = document.querySelector("#text"); var selObj = window.getSelection(); var contains = selObj.containsNode(text);
從 DOM
中刪除選中的文檔片斷。
無
var selObj = window.getSelection(); selObj.deleteFromDocument();
移動選區的焦點(focus
)到指定的點。選區的錨點(anchor
)不會移動。選區將從錨點(anchor
)開始到新的焦點(focus
),無論方向。
node
: 焦點(focus
)會被移至此節點內。 offset
: 可選,默認值爲0,焦點(focus
)會被移至 node
內的偏移位置。
<div id="text">文本</div>
var text = document.querySelector("#text"); var selObj = window.getSelection(); selObj.extend(text);
返回一個當前選區包含的 Range
對象。
index
: 該參數指定 Range
對象的索引。若是該數值大於或等於 rangeCount
,將會報錯。
//獲取一個 Selection 對象 var selObj = window.getSelection(); //獲取一個 Range 對象 var rangeObj = selObj.getRangeAt(0);
經過文本命令來更改當前選區或光標位置。
alter
:改變類型,傳入 move
來移動光標位置,或者 extend
來擴展當前選區。 direction
:調整選區的方向。你能夠傳入 forward
或 backward
來根據選區內容的語言書寫方向來調整。或者使用 left
或 right
來指明一個明確的調整方向。 granularity
:調整的距離顆粒度。可選值有 character
、word
、sentence
、line
、paragraph
、lineboundary
、sentenceboundary
、paragraphboundary
、documentboundary
。
var selection = window.getSelection(); selection.modify("extend", "forward", "word");
會從當前 Selection
對象中移除全部的 Range
對象,取消全部的選擇。
無
var selObj = window.getSelection(); selObj.removeAllRanges();
將一個 Range
對象從選區中移除。
range
: 一個將從選區中移除的 Range對象
。
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0) selObj.removeRange(rangeObj);
把指定元素的全部子元素設置爲選區(該元素自己除外),並取消以前的選區。
parentNode
: 指定元素
<div id="selectAll"> <div>文本1</div> <div>文本2</div> </div>
var selectAll = document.querySelector("#selectAll"); var selObj = window.getSelection(); selObj.selectAllChildren(selectAll);
選中兩個特定 DOM
節點之間的內容。
anchorNode
: 選中內容的開始節點 anchorOffset
:選區起始位置在 anchorNode
內的偏移量。
若是 anchorNode
是文本節點,表示選區起始位置在該節點第幾個字符位置。
若是 anchorNode
是元素節點,表示選區起始位置在該節點內第幾個子節點的位置。 focusNode
: 選中內容的結束節點 focusOffset
: 選區終止位置在 focusNode
內的偏移量。
若是 focusNode
是文本節點,表示選區終止位置在該節點第幾個字符位置。
若是 focusNode
是元素節點,表示選區終止位置在該節點內第幾個子節點的位置。
<div id="start"></div> <div id="end"></div>
var start = document.querySelector("#start"); var end = document.querySelector("#end"); var selObj = window.getSelection(); selObj.setBaseAndExtent(start,0,end,0);
返回表明當前 Selection
對象的字符串,例如當前選擇的文本。
無
var selObj = window.getSelection(); selObj.toString();
Range
對象表示被選中的文檔片斷。一個 Range
對象可能包含整個元素節點,也可能包含元素節點的一部分,例如文本節點的一部分文字。用戶一般只能選擇一個 Range
對象,可是有的時候用戶也有可能選擇多個 Range
對象(只有火狐瀏覽器能夠選擇多個 Range
對象)。
能夠用 Document 對象的 Document.createRange 方法建立 Range
,也能夠用 Selection 對象的 getRangeAt 方法獲取 Range
。另外,還能夠經過 Document 對象的構造函數 Range() 來獲得 Range
。
Boolean
值。startContainer
和 endContainer
的最深一級的節點。Range
終點位置的節點。endOffset:
endContainer
是文本節點、註釋節點,返回該節點第一個字到選區邊界的字符個數(即被選中的字符個數)。endContainer
是元素節點,返回選區終止位置以後第一個節點以前的同級節點總數。Range
開始位置的節點。startOffset:
startContainer
是文本節點、註釋節點,返回該節點第一個字到選區邊界的字符個數(即未被選中的字符個數)。startContainer
是元素節點,返回選區起始位置第一個節點以前的同級節點總數。注意:
以上全部屬性都是只讀屬性。
返回一個文檔片斷,它是 Range
對象中全部節點的副本。
無
// 在文檔中插入選中元素 var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); documentFragment = rangeObj.cloneContents(); document.body.appendChild(documentFragment);
返回一個 Range
對象的副本(兩個對象各自作出改變,都不會影響另外一方)。
無
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); clone = rangeObj.cloneRange();
向開始或結束方向摺疊 Range
。
toStart
: 可選,Boolean
值(默認值 false
), true
摺疊到 Range
的開始方向,false
摺疊到結束方向。
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); rangeObj.collapse(true);
比較兩個 Range
對象的起始位置節點或結束位置節點。
how
表示比較方法的常量:
Range.END_TO_END :比較 sourceRange 對象的結束位置節點和原 Range 對象的結束位置節點。 Range.END_TO_START :比較 sourceRange 對象的結束位置節點和原 Range 對象的起始位置節點。 Range.START_TO_END :比較 sourceRange 對象的起始位置節點和原 Range 對象的結束位置節點。 Range.START_TO_START :比較 sourceRange 對象的起始位置節點和原 Range 對象的起始位置節點。
sourceRange
: 一個與原 Range
對象比較的 Range
對象。
compare
表示一個數字:
-1 :原 Range 對象的比較節點在 sourceRange 對象的比較節點以前 0 :原 Range 對象的比較節點在 sourceRange 對象的比較節點的相同位置 1 :原 Range 對象的比較節點在 sourceRange 對象的比較節點以後
<div id="range">range</div> <div id="sourceRange">sourceRange</div>
var range, sourceRange, compare; range = document.createRange(); range.selectNode(document.querySelector("#rang")); sourceRange = document.createRange(); sourceRange.selectNode(document.querySelector("#sourceRange")); compare = range.compareBoundaryPoints(Range.START_TO_END, sourceRange);
判斷指定節點是在 Range
對象的以前、相同仍是以後位置。
referenceNode
: 與 Range
對象進行比較的節點。 offset
: 在 referenceNode
內的偏移量。
若是 referenceNode
是文本節點、註釋節點,offset
表示在該節點中字符的偏移位置。
若是 referenceNode
是元素節點,offset
表示在該節點中子元素的偏移位置。
<div id="range">range</div> <div id="referenceNode">referenceNode</div>
range = document.createRange(); range.selectNode(document.querySelector("#range")); returnValue = range.comparePoint(document.querySelector("#referenceNode"), 0);
將 HTML
字符串轉換爲文檔片斷
tagString
: 要轉換的 HTML
字符串。
<div id="range">range</div>
var tagString = "<div>node</div>"; var range = document.createRange(); range.selectNode(document.querySelector("#range")); var documentFragment = range.createContextualFragment(tagString); document.body.appendChild(documentFragment);
從 DOM
中刪除選中的文檔片斷,不返回刪除的文檔片斷。
無
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); rangeObj.deleteContents();
從 DOM
中刪除選中的文檔片斷,返回刪除的文檔片斷(不保留 DOM
事件)。
無
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); rangeObj.extractContents();
返回一個 DOMRect 對象,表示整個選區的位置信息。
無
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); var boundingRect = rangeObj.getBoundingClientRect();
返回一個選區內全部元素調用 Element.getClientRects() 方法所得結果的列表。表示選區在屏幕上所佔的區域。
無
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); var boundingRect = rangeObj.getClientRects();
在選區開始處插入一個節點。
newNode
: 須要插入的節點
<div id="insertNode">insertNode</div> <div id="node">node</div>
range = document.createRange(); newNode = document.querySelector("#node"); range.selectNode(document.querySelector("#insertNode")); range.insertNode(newNode);
返回一個 Boolean
值,判斷指定節點和 Range
對象是否相交。
referenceNode
:須要比較的節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); referenceNode = document.querySelector("#referenceNode"); rangeObj.intersectsNode(referenceNode);
返回一個 Boolean
值,判斷指定節點是否在 Range
對象內。
referenceNode
:指定節點 offset
:在 referenceNode
內的偏移量。
若是 referenceNode
是文本節點,offset
表示在該節點中字符的偏移位置。
若是 referenceNode
是元素節點,offset
表示在該節點中子元素的偏移位置。
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); referenceNode = document.querySelector("#referenceNode"); rangeObj.isPointInRange(referenceNode,0);
將指定節點包含在 Range
對象內。
referenceNode
:指定節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); referenceNode = document.querySelector("#referenceNode"); rangeObj.selectNode(referenceNode);
將指定節點的內容包含在 Range
對象內。
referenceNode
:指定節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); referenceNode = document.querySelector("#referenceNode"); rangeObj.selectNodeContents(referenceNode);
設置選區的終止位置。
endNode
:終止位置所在的節點 endOffset
:在 endNode
內的偏移量。
若是 endNode
是文本節點、註釋節點,endOffset
表示在該節點中字符的偏移位置。
若是 endNode
是元素節點,endOffset
表示在該節點中子元素的偏移位置。
<div id="endNode">endNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); var endNode = document.querySelector("#endNode"); rangeObj.setEnd(endNode,0)
設置選區的結束位置在指定節點以後。
referenceNode
:指定節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); var referenceNode = document.querySelector("#referenceNode"); rangeObj.setEndAfter(referenceNode)
設置選區的結束位置在指定節點以前。
referenceNode
:指定節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); var referenceNode = document.querySelector("#referenceNode"); rangeObj.setEndBefore(referenceNode)
設置選區的起始位置。
startNode
:起始位置所在的節點 startOffset
:在 startNode
內的偏移量。
若是 startNode
是文本節點、註釋節點,startOffset
表示在該節點中字符的偏移位置。
若是 startNode
是元素節點,startOffset
表示在該節點中子元素的偏移位置。
<div id="startNode">startNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); startNode = document.querySelector("#startNode"); rangeObj.setStart(startNode,0)
設置選區的起始位置在指定節點以後。
referenceNode
:指定節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); referenceNode = document.querySelector("#referenceNode"); rangeObj.setStartAfter(referenceNode)
設置選區的起始位置在指定節點以前。
referenceNode
:指定節點
<div id="referenceNode">referenceNode</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); referenceNode = document.querySelector("#referenceNode"); rangeObj.setStartBefore(referenceNode)
把指定節點插入選區的起始位置,而後把指定節點的內容替換爲選區的內容。
newParent
:指定節點
<div id="newParent">newParent</div>
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); newParent = document.querySelector("#newParent"); rangeObj.surroundContents(newParent)
返回表明當前 Range
對象的字符串,例如當前選擇的文本。
無
var selObj = window.getSelection(); var rangeObj = selObj.getRangeAt(0); var rangeStr = rangeObj.toString();
一個 Selection
對象表示用戶選擇的區域(Range
對象)的集合,一般它只包含一個區域,訪問方式以下:
//獲取一個 Selection 對象 var selObj = window.getSelection(); //獲取一個 Range 對象 var rangeObj = selObj.getRangeAt(0);
只有火狐瀏覽器實現了多個區域,以下圖所示:
使用 ::selection 選擇器能夠匹配被選中的部分。
目前只有一小部分 CSS 屬性能夠用於 ::selection 選擇器: