Javascript从页面上的任何textinput / textarea获取选定的文本

时间:2011-06-20 18:58:30

标签: javascript bookmarklet

如果我不知道哪一个是活动的(聚焦的),如何从文本框/文本区域中获取所选文本。我正在尝试创建一个小书签,它将纠正页面上任何类型输入中的选定文本。

1 个答案:

答案 0 :(得分:17)

对于选择,您需要selectionStartselectionEnd

对于当前关注的元素,请使用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);