您好,登錄后才能下訂單哦!
這篇“javascript的range使用方法有哪些”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“javascript的range使用方法有哪些”文章吧。
javascript的range對象是指html文檔中的區域,其使用方法如“var elem=range.commonAncestorContainer;if(elem.nodeType != 1){...}”。
本文操作環境:Windows7系統、javascript1.8.5版、Dell G3電腦。
javascript的range用法是什么?
JS Range 對象的使用
一:什么是Range對象
Range是指html文檔中的區域,如用戶用鼠標拖動選中的區域,如下圖:
通過Range對象,可以獲取用戶選中的區域,或者指定選中區域,得到Range的起點和終點、修改或者復制里邊的文本,甚至是html。在富文本編輯器開發中,經常會使用到這些功能。
二:獲取當前的選區
由于兼容性的問題,需要區分ie瀏覽器,
var selection, range; if (window.getSelection) { //現代瀏覽器 selection = window.getSelection(); } else if (document.selection) { //IE selection = document.selection.createRange(); } //Range對象 range = selection.getRangeAt(0);
三:range屬性
> collapsed 如果范圍的開始點和結束點在文檔的同一位置,則為 true,即范圍是空的,或折疊的。 > commonAncestorContainer 范圍的開始點和結束點的(即它們的祖先節點)、嵌套最深的 Document 節點。 > endContainer 包含范圍的結束點的 Document 節點。 > endOffset endContainer 中的結束點位置。 > startContainer 包含范圍的開始點的 Document 節點。 > startOffset startContainer中的開始點位置。
四:range操作
//選中區域的文字 var text = range.toString(); //選中區域的Element元素 var elem = range.commonAncestorContainer; if(elem.nodeType != 1){ elem = elem.parentNode; } //選中區域的html var span = document.createElement('SPAN'); span.appendChild(range.cloneContents()); //選區是否為空 var isSelectionEmpty = false; if (range.startContainer === range.endContainer) { if (range.startOffset === range.endOffset) { isSelectionEmpty = true; } }
以上就是關于“javascript的range使用方法有哪些”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。