在<textarea>使用JavaScript的情况下,如何获得插入符的位置?
<textarea>
例如: This is| a text
This is| a text
这应该返回7。
7
您如何获得它来返回光标/选择周围的字符串?
例如:'This is', '', ' a text'。
'This is', '', ' a text'
如果突出显示单词“ is”,则它将返回'This ', 'is', ' a text'。
'This ', 'is', ' a text'
使用Firefox,Safari(和其他基于Gecko的浏览器),您可以轻松地使用textarea.selectionStart,但对于IE则无法使用,因此您必须执行以下操作:
function getCaret(node) { if (node.selectionStart) { return node.selectionStart; } else if (!document.selection) { return 0; } var c = "\001", sel = document.selection.createRange(), dul = sel.duplicate(), len = 0; dul.moveToElementText(node); sel.text = c; len = dul.text.indexOf(c); sel.moveStart('character',-1); sel.text = ""; return len; }
我还建议您检查jQueryFieldSelection插件,它可以使您做到这一点以及更多…
编辑: 我实际上重新实现了上面的代码:
function getCaret(el) { if (el.selectionStart) { return el.selectionStart; } else if (document.selection) { el.focus(); var r = document.selection.createRange(); if (r == null) { return 0; } var re = el.createTextRange(), rc = re.duplicate(); re.moveToBookmark(r.getBookmark()); rc.setEndPoint('EndToStart', re); return rc.text.length; } return 0; }