如果我不知道哪一个是事件的(重点),如何从文本框/文本区域获取选定的文本。我正在尝试创建一个小书签,它将更正页面上任何类型输入中的选定文本。
最佳答案
对于选择,您需要 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);
关于Javascript 从页面上的任何文本输入/文本区域获取选定的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6416020/