gpt4 book ai didi

javascript - 在不渲染的情况下测量文本宽度/高度

转载 作者:技术小花猫 更新时间:2023-10-29 12:01:57 25 4
gpt4 key购买 nike

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

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

例如。

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

如果我知道 someText 将呈现在一行中的宽度以及该行的长度,我可以轻松地对组件高度进行合理的估计。

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

最佳答案

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

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());

Demo using

编辑

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

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

编辑

Canvas 规范没有为我们提供测量字符串高度的方法,因此为此我们可以使用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']);

关于javascript - 在不渲染的情况下测量文本宽度/高度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31305071/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com