Ответ 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());
ИЗМЕНИТЬ
Решение с использованием холста не самое лучшее, каждый браузер имеет разный размер холста.
Здесь является хорошим решением для получения размера текста с использованием временного элемента. Демо
ИЗМЕНИТЬ
Спецификация canvas не дает нам метода для измерения высоты строки, поэтому для этого мы можем использовать parseInt(context.font)
.
Чтобы получить ширину и высоту. Этот трюк работает только с размером пикселей.
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']);