测量文本宽度/高度而不渲染
Measuring text width/height without rendering
是否有任何方法可以在不呈现实际元素的情况下获得文本宽度的估计?比如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());
使用
演示编辑
使用画布的解决方案不是最好的,每个浏览器处理不同的画布大小。
下面是使用临时元素获取文本大小的一个很好的解决方案。演示编辑
画布规格没有给我们测量字符串高度的方法,所以我们可以使用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']);
相关文章:
- jquery插件或javascript方法自动调整文本输入(而非文本区域)(固定宽度)可变高度的大小
- 自动缩放图像以匹配文本高度
- 可以设置输入类型=文件的文本框的高度
- 使用jquery调整文本区域的高度
- 如何使文本框的高度与窗口的高度相同
- 使用jquery将文本的高度调整为图像的高度
- 始终具有窗口高度的文本区域
- 在 JavaScript 中重置文本区域高度
- 查找文本区域的可见高度
- 动态文本区域高度
- jQuery load() 函数更改输入文本的高度
- 必须使用 d3 库将文本高度保存在 d 中
- 钛应用器动态文本区域高度增加
- 添加动态文本框时更新动态高度
- 文本框在 JavaScript 警报后更改高度和边框宽度
- 文本区域只读自动高度(用所选日期填充)
- 表单“提交”按钮文本(和宽度/高度/值)在按键时消失或更改BTN值
- 通过自动调整内容高度来防止文本区域 ENTER 行为
- 零高度文本区域不是零像素高
- 如何建立一个自动高度文本区域