>本文档提供了用于管理输入字段中文本选择的代码段。 现代铬和Firefox使用.setSelectionRange()
,但是Firefox要求该元素事先具有焦点。
获得光标位置:
<code class="language-javascript">jQuery.fn.getCursorPosition = function(){ if(this.length == 0) return -1; return $(this).getSelectionStart(); };</code>
获得选择开始:
<code class="language-javascript">jQuery.fn.getSelectionStart = function(){ if(this.length == 0) return -1; input = this[0]; var pos = input.value.length; if (input.createTextRange) { var r = document.selection.createRange().duplicate(); r.moveEnd('character', input.value.length); if (r.text == '') pos = input.value.length; pos = input.value.lastIndexOf(r.text); } else if(typeof(input.selectionStart)!="undefined") pos = input.selectionStart; return pos; };</code>
设置光标位置:
<code class="language-javascript">jQuery.fn.setCursorPosition = function(pos) { this.each(function(index, elem) { if (elem.setSelectionRange) { elem.setSelectionRange(pos, pos); } else if (elem.createTextRange) { var range = elem.createTextRange(); range.collapse(true); range.moveEnd('character', pos); range.moveStart('character', pos); range.select(); } }); return this; };</code>
设置光标位置(替代):
<code class="language-javascript">function setCursorPos(node,pos){ var node = (typeof node == "string" || node instanceof String) ? document.getElementById(node) : node; node.focus(); // Crucial for Firefox if(!node) return false; else if(node.createTextRange){ var textRange = node.createTextRange(); textRange.collapse(true); textRange.moveStart('character', pos); textRange.moveEnd('character', 0); textRange.select(); return true; }else if(node.setSelectionRange){ node.setSelectionRange(pos,pos); return true; } return false; }</code>
>常见问题: FAQ部分提供了清晰的解释,
,,浏览器兼容性和参数的处理。 答案简洁明了。 这里不需要更改。setSelectionRange
>
以上是输入文本选择代码段的详细内容。更多信息请关注PHP中文网其他相关文章!