栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在HTML中选择后持久保留范围对象的更改

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在HTML中选择后持久保留范围对象的更改

对于每个选择,您可以将所选范围序列化为字符偏移量,并在重新加载时使用如下所示再次将其反序列化:

码:

var saveSelection, restoreSelection;if (window.getSelection && document.createRange) {    saveSelection = function(containerEl) {        var range = window.getSelection().getRangeAt(0);        var preSelectionRange = range.cloneRange();        preSelectionRange.selectNodeContents(containerEl);        preSelectionRange.setEnd(range.startContainer, range.startOffset);        var start = preSelectionRange.toString().length;        return { start: start, end: start + range.toString().length        };    };    restoreSelection = function(containerEl, savedSel) {        var charIndex = 0, range = document.createRange();        range.setStart(containerEl, 0);        range.collapse(true);        var nodeStack = [containerEl], node, foundStart = false, stop = false;        while (!stop && (node = nodeStack.pop())) { if (node.nodeType == 3) {     var nextCharIndex = charIndex + node.length;     if (!foundStart && savedSel.start >= charIndex && savedSel.start <= nextCharIndex) {         range.setStart(node, savedSel.start - charIndex);         foundStart = true;     }     if (foundStart && savedSel.end >= charIndex && savedSel.end <= nextCharIndex) {         range.setEnd(node, savedSel.end - charIndex);         stop = true;     }     charIndex = nextCharIndex; } else {     var i = node.childNodes.length;     while (i--) {         nodeStack.push(node.childNodes[i]);     } }        }        var sel = window.getSelection();        sel.removeAllRanges();        sel.addRange(range);    }} else if (document.selection) {    saveSelection = function(containerEl) {        var selectedTextRange = document.selection.createRange();        var preSelectionTextRange = document.body.createTextRange();        preSelectionTextRange.moveToElementText(containerEl);        preSelectionTextRange.setEndPoint("EndToStart", selectedTextRange);        var start = preSelectionTextRange.text.length;        return { start: start, end: start + selectedTextRange.text.length        }    };    restoreSelection = function(containerEl, savedSel) {        var textRange = document.body.createTextRange();        textRange.moveToElementText(containerEl);        textRange.collapse(true);        textRange.moveEnd("character", savedSel.end);        textRange.moveStart("character", savedSel.start);        textRange.select();    };}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/420645.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号