我只想允许从左到右进行选择,因此锚节点始终是 DOM 树中的第一个节点(相对于焦点节点)。
有没有一种简单的方法来测试锚节点是否在焦点节点之前?
我只想允许从左到右进行选择,因此锚节点始终是 DOM 树中的第一个节点(相对于焦点节点)。
有没有一种简单的方法来测试锚节点是否在焦点节点之前?
这是一种简单的方法,它使用了这样一个事实,即将 DOM 范围的结尾设置在文档中比范围开头更早的位置会折叠范围。我认为这将在 Firefox 2 中中断,它在处理此问题时存在错误,但该浏览器的用户数量很少。
function isSelectionBackwards() {
var backwards = false;
if (window.getSelection) {
var sel = window.getSelection();
if (!sel.isCollapsed) {
var range = document.createRange();
range.setStart(sel.anchorNode, sel.anchorOffset);
range.setEnd(sel.focusNode, sel.focusOffset);
backwards = range.collapsed;
range.detach();
}
}
return backwards;
}