我需要计算width和height使用JavaScript的选择/高亮文本.
我使用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 };
}
Run Code Online (Sandbox Code Playgroud)
的left&的top坐标是否被正确显示.要计算宽度和高度,我也需要right和bottom位置.
所以我添加了几行代码来找到bottom&right位置(这里有代码 - http://jsfiddle.net/pankajparashar/kv2Bp/).但令我惊讶的是,代码显示left&right坐标始终相同,即使它们之间存在明显差异(仅在firefox中测试).
有与没有问题top与的bottom位置,因为他们是完美的工作,这将帮我算算高度.但是为了计算宽度,我仍然需要正确right的坐标.
任何人都可以用代码指出任何缺陷吗?或任何替代方法,使用它我可以计算所选文本的宽度和高度?
Tim*_*own 14
这里有一些代码来获取选择的边界矩形的尺寸.它与原始代码非常相似.
function getSelectionDimensions() {
var sel = document.selection, range;
var width = 0, height = 0;
if (sel) {
if (sel.type != "Control") {
range = sel.createRange();
width = range.boundingWidth;
height = range.boundingHeight;
}
} else if (window.getSelection) {
sel = window.getSelection();
if (sel.rangeCount) {
range = sel.getRangeAt(0).cloneRange();
if (range.getBoundingClientRect) {
var rect = range.getBoundingClientRect();
width = rect.right - rect.left;
height = rect.bottom - rect.top;
}
}
}
return { width: width , height: height };
}
Run Code Online (Sandbox Code Playgroud)