如果我不知道哪一个是活动的(聚焦的),如何从文本框/文本区域中获取所选文本。我正在尝试创建一个小书签,它将纠正页面上任何类型输入中的选定文本。
答案 0 :(得分:17)
对于选择,您需要selectionStart
和selectionEnd
。
对于当前关注的元素,请使用document.activeElement
。
因此,您可以使用http://jsfiddle.net/rBPte/1/。
作为组合正如Tim Down指出的那样,对于Internet Explorer 8或更低版本,您需要更复杂的解决方案:Caret position in textarea, in characters from the start
function getText(elem) { // only allow input[type=text]/textarea
if(elem.tagName === "TEXTAREA" ||
(elem.tagName === "INPUT" && elem.type === "text")) {
return elem.value.substring(elem.selectionStart,
elem.selectionEnd);
// or return the return value of Tim Down's selection code here
}
return null;
}
setInterval(function() {
var txt = getText(document.activeElement);
document.getElementById('div').innerHTML =
txt === null ? 'no input selected' : txt;
}, 100);