无需渲染即可测量文本宽度/高度

IT技术 javascript html text reactjs dimension
2021-04-05 09:33:12

有没有办法在不渲染实际元素的情况下估算文本宽度?像画布 TextMetrics 之类的东西?

案例:我需要估计 ReactList 的元素高度。为此,我需要大致知道文本元素需要多少空间(或它们将跨越多少行)。

例如。

render(){
    return <div><SomeComponentWithKnownDims/><p>{this.props.someText}</p></div>;
}

如果我知道 someText 将被渲染成一行的宽度以及该行的长度,我就可以很容易地对组件高度进行适当的估计。

编辑:请注意,这对性能非常关键,不应触及 DOM

1个回答

请检查这个。是使用画布的解决方案

function get_tex_width(txt, font) {
        this.element = document.createElement('canvas');
        this.context = this.element.getContext("2d");
        this.context.font = font;
        return this.context.measureText(txt).width;
    }
    alert('Calculated width ' + get_tex_width("Hello World", "30px Arial"));
    alert("Span text width "+$("span").width());

演示使用

编辑

使用画布的解决方案并不是最好的,每个浏览器处理不同的画布大小。

是使用临时元素获取文本大小的一个很好的解决方案。 演示

编辑

画布规范没有给我们测量字符串高度的方法,因此我们可以使用parseInt(context.font). 获取宽度和高度。此技巧仅适用于 px 大小。

function get_tex_size(txt, font) {
    this.element = document.createElement('canvas');
    this.context = this.element.getContext("2d");
    this.context.font = font;
    var tsize = {'width':this.context.measureText(txt).width, 'height':parseInt(this.context.font)};
    return tsize;
}
var tsize = get_tex_size("Hello World", "30px Arial");

alert('Calculated width ' + tsize['width'] + '; Calculated height ' + tsize['height']);
会失败em,不知道为什么,因为它确实适用于%和 视口单位。另请注意,在此上下文中thiswindow对象,因此您实际上是在创建全局变量elementcontext.
2021-05-23 09:33:12
@Kaiido 谢谢你的评论。是的,画布处理不同的 % 和 em 大小。所以这仅适用于 px 尺寸。因此,获得 DOM 中宽度的唯一方法是创建临时元素,将其添加到 DOM,应用样式和获取大小。
2021-05-23 09:33:12
但主要问题仍然是你确实在玩全局变量
2021-05-23 09:33:12
不实际上它确实适用于%视口单位(vh,vw ...),但它不适用于em,这很奇怪
2021-05-29 09:33:12
由于性能要求,临时元素并不真正起作用。不过,canvas 是我的首选自动提款机。我想用 position:fixed 和 x-index:-1000 制作一些零尺寸的画布,然后重新使用 measureText 的上下文。
2021-06-14 09:33:12