Javascript Contenteditable-将CursorCaret设置为索引

Javascript Contenteditable-将CursorCaret设置为索引,第1张

Javascript Contenteditable-将Cursor / Caret设置为索引

这是从HTML中选择后持久保留范围对象的更改而来的一个答案。请记住,这在几个方面都不是完美的(就像使用相同方法的MaxArt一样):首先,仅考虑文本节点,这意味着

<br>
索引所隐含的换行符和块元素不包括在索引中;其次,考虑所有文本节点,甚至是那些被CSS隐藏的内部
<script>
元素或内部元素。第三,连续折叠在页面上的空白字符都包含在索引中;最后,IE<= 8的规则再次有所不同,因为它使用了不同的机制。

var setSelectionByCharacterOffsets = null;if (window.getSelection && document.createRange) {    setSelectionByCharacterOffsets = function(containerEl, start, end) {        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 && start >= charIndex && start <= nextCharIndex) {         range.setStart(node, start - charIndex);         foundStart = true;     }     if (foundStart && end >= charIndex && end <= nextCharIndex) {         range.setEnd(node, 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) {    setSelectionByCharacterOffsets = function(containerEl, start, end) {        var textRange = document.body.createTextRange();        textRange.moveToElementText(containerEl);        textRange.collapse(true);        textRange.moveEnd("character", end);        textRange.moveStart("character", start);        textRange.select();    };}


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5148736.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-17
下一篇 2022-11-17

发表评论

登录后才能评论

评论列表(0条)

保存