我正在制作一个将屏幕分成两个窗口的 Web 应用程序,一侧是基于 Web 的文本编辑器,另一侧只是一个普通窗口。我正在尝试找到一种方法,让用户在浏览器端突出显示一些文本,然后将突出显示的文本自动保存到一个字符串中,然后我就可以在其中操作该字符串。
有人有什么想法吗?任何帮助将不胜感激。
我正在制作一个将屏幕分成两个窗口的 Web 应用程序,一侧是基于 Web 的文本编辑器,另一侧只是一个普通窗口。我正在尝试找到一种方法,让用户在浏览器端突出显示一些文本,然后将突出显示的文本自动保存到一个字符串中,然后我就可以在其中操作该字符串。
有人有什么想法吗?任何帮助将不胜感激。
function getSelectionText() {
var text = "";
if (window.getSelection) {
text = window.getSelection().toString();
} else if (document.selection && document.selection.type != "Control") {
text = document.selection.createRange().text;
}
return text;
}
$(document).ready(function (){
$('div').mouseup(function (e){
alert(getSelectionText())
})
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div>
Hello, this is a highlight text test
</div>
所以你在这里有两个步骤。
可以通过 js 调用访问在文档上选择的任何文本:
window.getSelection()
但这是特定于浏览器的。因此,您可以使用此代码片段来涵盖从所有浏览器中抓取选定的文本。
function getSelectedText () {
var txt = ''
if (window.getSelection) {
txt = window.getSelection();
} else if (document.getSelection) {
txt = document.getSelection();
} else if (document.selection) {
txt = document.selection.createRange().text;
}
return txt;
}
我假设您正在使用像 jQuery 这样的库。这样可以帮助处理 mouseup 事件。您可能不想捕获整个文档的选择。所以你可以绑定到你需要的任何元素。像我的jsfiddle在这里:http: //jsfiddle.net/xh799/