Я пытаюсь использовать jquery для записи быстрой функции, которая вычисляет ширину пикселя строки на странице html, а затем обрезает строку до тех пор, пока она не достигнет идеальной ширины пикселя...
Однако он не работает (текст не обрезается)...
Вот код, который у меня есть:
function constrain(text, original, ideal_width){
var temp_item = ('<span class="temp_item" style="display:none;">'+ text +'</span>');
$(temp_item).appendTo('body');
var item_width = $('span.temp_item').width();
var ideal = parseInt(ideal_width);
var smaller_text = text;
while (item_width > ideal) {
smaller_text = smaller_text.substr(0, (smaller_text-1));
$('.temp_item').html(text);
item_width = $('span.temp_item').width();
}
var final_length = smaller_text.length;
if (final_length != original) {
return (smaller_text + '…');
} else {
return text;
}
}
Вот как я его вызываю со страницы:
$('.service_link span:odd').each(function(){
var item_text = $(this).text();
var original_length = item_text.length;
var constrained = constrain(item_text, original_length,175);
$(this).html(constrained);
});
Любые идеи о том, что я делаю неправильно? Если есть способ сделать это быстрее (например, сортировка пузыря), это тоже будет здорово.
Спасибо!