编辑:由于您需要这个 FF 扩展,您可以跳过 IE 的所有功能,您需要做的一切是:
window.getSelection().getRangeAt(0).commonAncestorContainer
有关范围的更多信息:https ://developer.mozilla.org/en/DOM/range
已经有一个类似的问题:
获取页面上的选定文本和选定节点?
我稍微修改了功能:
<script type="text/javascript">
function getTextSelection() {
if(document.selection)
return document.selection;
else if(window.getSelection)
return window.getSelection();
else if(document.getSelection)
return document.getSelection();
else
return false;
}
function getSelectionRange() {
var selection = getTextSelection();
if(selection.getRangeAt)
return selection.getRangeAt(0);
else if (selection.createRange)
return selection.createRange();
else
return false;
}
function getSelectionParent(r) {
if(r.parentElement)
return r.parentElement;
else if(r.commonAncestorContainer)
return r.commonAncestorContainer;
else
return false;
}
</script>
HTML:
<body>
<p><em>This is just some random text. </em><strong>Select me and then click the button!!!</strong></p>
<p><input type="button" value="Parent element?" onclick="alert('The selection\'s parent element is: ' + getSelectionParent(getSelectionRange()).nodeName);" /></p>
</body>
我在 IE6,7 和 FF3.0 中测试了这些东西。工作没有任何问题。您必须注意的唯一一件事是 IE 与 FF 不同,它会忽略文本节点。
如果您想自己尝试一下:http: //dev.freedig.org/files/selection.html