【发布时间】:2012-09-26 22:30:03
【问题描述】:
我需要使用 JavaScript 计算所选/突出显示的文本的 width 和 height。
我使用以下 Tim Down 编写的代码作为起点,
function getSelectionCoords() {
var sel = document.selection, range;
var x = 0, y = 0;
if (sel) {
if (sel.type != "Control") {
range = sel.createRange();
range.collapse(true);
x = range.boundingLeft;
y = range.boundingTop;
}
} else if (window.getSelection) {
sel = window.getSelection();
if (sel.rangeCount) {
range = sel.getRangeAt(0).cloneRange();
if (range.getClientRects) {
range.collapse(true);
var rect = range.getClientRects()[0];
x = rect.left;
y = rect.top;
}
}
}
return { x: x, y: y };
}
left 和 top 坐标显示正确。要计算宽度和高度,我还需要 right 和 bottom 位置。
所以我添加了几行代码来查找 bottom 和 right 位置(代码可在此处获得 - http://jsfiddle.net/pankajparashar/kv2Bp/)。但令我惊讶的是,代码显示left 和right 坐标始终相同,即使它们之间存在明显差异(仅在Firefox 中测试)。
top 和bottom 位置没有问题,因为它们工作得很好,这将帮助我计算高度。但是要计算宽度,我仍然需要正确的right 坐标。
任何人都可以指出代码的任何缺陷吗?或任何替代方法,我可以使用它来计算所选文本的宽度和高度?
【问题讨论】:
标签: javascript