Gizli taşmalı bir yayılma alanındaki noktaları (“…”) nasıl gösterebilirim?


166

CSS'm:

#content_right_head span
{
  display:inline-block;
  width:180px;
  overflow:hidden !important;
}

Şimdi gösteriyor içerik içeriği

Ama içerik içeriği gibi göstermek istiyorum ...

İçerikten sonra noktaları göstermem gerekiyor. İçerik dinamik olarak veritabanından geliyor.

Yanıtlar:


382

Bunun için text-overflow: ellipsis;özelliği kullanabilirsiniz . Böyle yaz

span {
    display: inline-block;
    width: 180px;
    white-space: nowrap;
    overflow: hidden !important;
    text-overflow: ellipsis;
}
<span>Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book</span>

JSFiddle


4
'Genişlik'i' maksimum genişlik 'olarak değiştirmenizi öneririm
Amir Mog

4
Duyarlı düzenler ne olacak? Genişliğim sabit değil, ne de maksimum genişlik.
Jp_

1
şimdi onclick'i kullanarak bunu nasıl genişletebilirim?
Ankush Rishi

2
IE11 ve firefox'ta bu çalışmaz. Bunun için harika bir çözüm var mı?
techie_questie

19

Metin taşması: üç nokta kullanıyorsanız, tarayıcı içeriği o kapta mümkün olan her şekilde gösterir. Ancak, noktalardan önceki harf sayısını belirtmek veya bazı içerikleri çıkarmak ve noktalar eklemek istiyorsanız, aşağıdaki işlevi kullanabilirsiniz.

function add3Dots(string, limit)
{
  var dots = "...";
  if(string.length > limit)
  {
    // you can also use substr instead of substring
    string = string.substring(0,limit) + dots;
  }

    return string;
}

gibi ara

add3Dots("Hello World",9);

çıktılar

Hello Wor...

Burada çalışırken görün

function add3Dots(string, limit)
{
  var dots = "...";
  if(string.length > limit)
  {
    // you can also use substr instead of substring
    string = string.substring(0,limit) + dots;
  }

    return string;
}



console.log(add3Dots("Hello, how are you doing today?", 10));


14

Bence sen arıyorsun text-overflow: ellipsis kombinasyon halindewhite-space: nowrap

Daha fazla ayrıntıyı burada görün


12

Bunu dene,

.truncate {
    display:inline-block;
    width:180px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

öğenize .truncatesınıf ekleyin .


DÜZENLE ,

Yukarıdaki çözüm tüm tarayıcılarda çalışmıyor. çapraz tarayıcı desteği ile jQuery eklentisini takip etmeyi deneyebilirsiniz.

(function ($) {
    $.fn.ellipsis = function () {
        return this.eachAsync({
            delay: 100,
            bulk: 0,
            loop: function (index) {
                var el = $(this);

                if (el.data("fullText") !== undefined) {
                    el.html(el.data("fullText"));
                } else {
                    el.data("fullText", el.html());
                }

                if (el.css("overflow") == "hidden") {
                    var text = el.html();
                    var t = $(this.cloneNode(true))
                                        .hide()
                                        .css('position', 'absolute')
                                        .css('overflow', 'visible')
                                        .width('auto')
                                        .height(el.height())
                                        ;

                    el.after(t);

                    function width() { return t.width() > el.width(); };

                    var func = width;
                    while (text.length > 0 && width()) {
                        text = text.substr(0, text.length - text.length * 25 / 100);
                        t.html(text + "...");
                    }

                    el.html(t.html());
                    t.remove();
                }
            }
        });
    };
})(jQuery);

nasıl aranır,

$("#content_right_head span").ellipsis();

widthözelliği olabilir 100%. Bunun gibi daha iyi olduğunu düşünüyorum: .truncate { display:inline-block; width:100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
Mehdi

4

Eh, "metin taşması: üç nokta" benim için çalıştı, ancak sınırım 'genişliğe' dayalıysa, satırlara uygulanabilecek bir çözüme ihtiyacım vardı ('genişlik' yerine 'yükseklik' üzerinde) Bu senaryoyu yaptım:

function listLimit (elm, line){
    var maxHeight = parseInt(elm.css('line-Height'))*line;

    while(elm.height() > maxHeight){
        var text = elm.text();
        elm.text(text.substring(0,text.length-10)).text(elm.text()+'...');
    }
}

Örneğin, h3'ümde sadece 2 satır olması gerektiğinde:

$('h3').each(function(){
   listLimit ($(this), 2)
})

Performans ihtiyaçları için en iyi uygulama olup olmadığını bilmiyorum ama benim için çalıştı.



0
 var tooLong = document.getElementById("longText").value;
    if (tooLong.length() > 18){
        $('#longText').css('text-overflow', 'ellipsis');
    }

-3

Cevabı için çok teşekkürler.

Benim sorunum, fare tıklaması ile yayılma metni göstermek / gizlemek istiyorum oldu. Böylece varsayılan olarak noktalı kısa metin gösterilir ve uzun metin tıklatıldığında görüntülenir. Tekrar tıklamak o uzun metni gizler ve kısa metni tekrar gösterir.

Yapması oldukça kolay: sadece metin taşması ile sınıf ekleme / kaldırma: üç nokta.

HTML:

<span class="spanShortText cursorPointer"  onclick="fInventoryShippingReceiving.ShowHideTextOnSpan(this);">Some really long description here</span>

CSS (.cursorPointer eklendiğinde kum ile aynı)

.spanShortText {
  display: inline-block;
  width: 100px;
  white-space: nowrap;
  overflow: hidden !important;
  text-overflow: ellipsis;
}

.cursorPointer {
  cursor: pointer;
}

JQuery bölümü - temelde sadece cSpanShortText sınıfını kaldırır / ekler.

  function ShowHideTextOnSpan(element) {
    var cSpanShortText = 'spanShortText';
    var $el = $(element);
    if ($el.hasClass(cSpanShortText)) {
      $el.removeClass(cSpanShortText)
    } else {
      $el.addClass(cSpanShortText);
    }
  }
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.