Pet*_*ter 7 javascript jquery textarea selection textselection
我有一个textarea,我想检查光标是在开始还是在结束(我不需要当前的位置).
有人知道一个简单的jQuery解决方案吗?
提前致谢!
彼得
假设你的意思是一个<input type="text">而不是一个textarea,这里是一个非jQuery解决方案(你仍然可以使用你的jQuery代码).它几乎肯定会比jQuery插件更少的代码.
更新于2011年11月12日
话虽如此,我已经为他的任务开发了一个jQuery插件,它确实比下面的代码更大.
var textInput = document.getElementById("your_id"), val = textInput.value;
var isAtStart = false, isAtEnd = false;
if (typeof textInput.selectionStart == "number") {
// Non-IE browsers
isAtStart = (textInput.selectionStart == 0);
isAtEnd = (textInput.selectionEnd == val.length);
} else if (document.selection && document.selection.createRange) {
// IE <= 8 branch
textInput.focus();
var selRange = document.selection.createRange();
var inputRange = textInput.createTextRange();
var inputSelRange = inputRange.duplicate();
inputSelRange.moveToBookmark(selRange.getBookmark());
isAtStart = inputSelRange.compareEndPoints("StartToStart", inputRange) == 0;
isAtEnd = inputSelRange.compareEndPoints("EndToEnd", inputRange) == 0;
}
alert("At start: " + isAtStart + ", at end: " + isAtEnd);
Run Code Online (Sandbox Code Playgroud)