Обрезать текст с помощью jQuery на основе ширины пикселя - PullRequest
16 голосов
/ 22 мая 2009

Я пытаюсь использовать 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 + '&hellip;');
    } 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);
});

Есть идеи, что я делаю не так? Если есть способ сделать это быстрее (например, пузырьковая сортировка), это тоже было бы здорово.

Спасибо!

Ответы [ 5 ]

33 голосов
/ 19 ноября 2010

Вместо того, чтобы взламывать это вместе со скриптом, почему бы просто не использовать CSS, чтобы указать ширину элемента, в который вы помещаете эту строку? Вы можете использовать text-overflow, чтобы сообщить браузеру об усечении с помощью многоточия.

.truncated { display:inline-block; max-width:100px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

text-overflow является декларацией CSS3, но поддерживается в IE 6+, WebKit 312.3+ (Safari 1.3 + / Chrome) и Opera 9+ (версии <10.7 требуют декларации <code>-o-text-overflow).

Обратите внимание, что этот не был реализован в Firefox до 7.0, а под 4% пользователей Firefox все еще используют старые версии (в основном, 3.6). Ваш текст все еще будет обрезан в более старых версиях, но многоточие не будет отображаться. Если вас беспокоит эта небольшая группа пользователей, вы можете использовать этот плагин jQuery , который ничего не делает в IE / WebKit / Opera / Firefox & ge; 7, но будет эмулировать text-overflow в Firefox & le; 6.

3 голосов
/ 22 мая 2009

На этой строке:

smaller_text = smaller_text.substr(0, (smaller_text-1));

вы, возможно, намеревались

smaller_text = smaller_text.substr(0, (smaller_text.length-1));

Решает ли это проблему?

0 голосов
/ 19 ноября 2010

Если у вас есть текст, и вы знаете нужный размер, почему бы просто не использовать substr?

Я сделал нечто подобное с

$('#history-1').text( $('#history-1').text().trim().substr(0,32) + "..." )
0 голосов
/ 09 декабря 2009

Функция принимает текст для проверки, ideal_width в пикселях и имя класса для CSS. Если ideal_width меньше ширины текста, он обрезает и добавляет ад, иначе он возвращает текст без изменений. Просто и работает! : -)

function constrain(text, ideal_width, className){

    var temp_item = ('<span class="'+className+'_hide" style="display:none;">'+ text +'</span>');
    $(temp_item).appendTo('body');
    var item_width = $('span.'+className+'_hide').width();
    var ideal = parseInt(ideal_width);
    var smaller_text = text;

    if (item_width>ideal_width){
        while (item_width > ideal) {
            smaller_text = smaller_text.substr(0, (smaller_text.length-1));
            $('.'+className+'_hide').html(smaller_text);
            item_width = $('span.'+className+'_hide').width();
        }
        smaller_text = smaller_text + '&hellip;'
    }
    $('span.'+className+'_hide').remove();
    return smaller_text;
}
0 голосов
/ 22 мая 2009

Спасибо, у меня все заработало - но оно работает только с первым элементом и останавливается, связано ли это с тем, как я объявляю переменные?

вот текущий код:

    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.length-1));
        $('.temp_item').html(smaller_text);
        item_width = $('span.temp_item').width();
    }

    var final_length = smaller_text.length;

    if (final_length != original) {
        return (smaller_text + '&hellip;');
    } else {
        return text;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...