java计算文字的宽度,计算所选文本的宽度和高度(javascript)

我需要使用

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 };

}

左和顶部坐标正在正确显示.要计算宽度&身高,我需要正确&底部位置也是如此.

所以我添加了几行代码找到底部&正确的位置(代码可用 – http://jsfiddle.net/pankajparashar/kv2Bp/).但令我吃惊的是,代码显示了左边的&正确的坐标总是相同的,即使它们之间有明显的区别(仅在Firefox中测试).

顶部和顶部没有问题底部位置,因为它们正常工作,这将有助于我计算高度.但是要计算宽度,我仍然需要正确的右侧坐标.

任何人可以用代码指出任何缺陷?或任何替代方法,使用我可以计算宽度&所选文字的高度?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值