HTML 텍스트 오버플로 줄임표 감지 사용됩니다. 그러나 모든 요소가 오버플로되지는

페이지에 블록 요소 모음이 있습니다. 모두 CSS 규칙 공백, 오버플로, 텍스트 오버플로가 설정되어 오버플로 텍스트가 잘리고 줄임표가 사용됩니다.

그러나 모든 요소가 오버플로되지는 않습니다.

어쨌든 자바 스크립트를 사용하여 어떤 요소가 오버플로하는지 감지 할 수 있습니까?

감사.

추가 된 예제 HTML 구조.

<td><span>Normal text</span></td>
<td><span>Long text that will be trimmed text</span></td>

SPAN 요소는 항상 셀에 맞으며 줄임표 규칙이 적용됩니다. 줄임표가 SPAN의 텍스트 내용에 적용되는시기를 감지하고 싶습니다.



답변

옛날 옛적에 나는 이것을해야했고, 내가 찾은 유일한 크로스 브라우저 신뢰할 수있는 솔루션은 해킹 작업이었습니다. 나는 이와 같은 솔루션의 가장 큰 팬은 아니지만 확실히 정확한 결과를 반복해서 산출합니다.

아이디어는 요소를 복제하고 경계 너비를 제거하고 복제 된 요소가 원본보다 넓은 지 테스트하는 것입니다. 그렇다면 잘릴 것입니다.

예를 들어, jQuery를 사용하면 :

var $element = $('#element-to-test');
var $c = $element
           .clone()
           .css({display: 'inline', width: 'auto', visibility: 'hidden'})
           .appendTo('body');

if( $c.width() > $element.width() ) {
    // text was truncated. 
    // do what you need to do
}

$c.remove();

나는 jsFiddle이를 입증하기 위해 만든 http://jsfiddle.net/cgzW8/2/

jQuery에 대한 사용자 정의 의사 선택기를 만들 수도 있습니다.

$.expr[':'].truncated = function(obj) {
  var $this = $(obj);
  var $c = $this
             .clone()
             .css({display: 'inline', width: 'auto', visibility: 'hidden'})
             .appendTo('body');

  var c_width = $c.width();
  $c.remove();

  if ( c_width > $this.width() )
    return true;
  else
    return false;
};

그런 다음 요소를 찾기 위해 사용하십시오

$truncated_elements = $('.my-selector:truncated');

데모 : http://jsfiddle.net/cgzW8/293/

잘만되면 이것이 도움이 될 것입니다.


답변

span 요소를 인수로 전달하여이 JS 함수를 시도하십시오.

function isEllipsisActive(e) {
     return (e.offsetWidth < e.scrollWidth);
}

답변

italo의 답변에 추가하여 jQuery를 사용 하여이 작업을 수행 할 수도 있습니다.

function isEllipsisActive($jQueryObject) {
    return ($jQueryObject.width() < $jQueryObject[0].scrollWidth);
}

또한 Smoky가 지적했듯이 width () 대신 jQuery outerWidth ()를 사용할 수 있습니다.

function isEllipsisActive($jQueryObject) {
    return ($jQueryObject.outerWidth() < $jQueryObject[0].scrollWidth);
}

답변

Christian Varga의 대답을 사용하거나 사용하려는 사람들은 성능 문제를 알고 있어야합니다.

이러한 방식으로 DOM을 복제 / 조작하면 리소스를 많이 사용하는 DOM 리플 로우 ( DOM 리플 로우에 대한 설명 참조) 발생 합니다 .

페이지의 100 개 이상의 요소에 Christian Varga의 솔루션을 사용하면 JS 스레드가 잠기는 동안 4 초의 리플 로우 지연이 발생했습니다. JS가 단일 스레드임을 고려하면 이는 최종 사용자에게 상당한 UX 지연을 의미합니다.

Italo Borssatto의 답변 이 인정되어야합니다. 프로파일 링 중에 약 10 배 더 빠릅니다.


답변

italo의 답변 은 매우 좋습니다! 그러나 조금 수정 해 보겠습니다.

function isEllipsisActive(e) {
   var tolerance = 2; // In px. Depends on the font you are using
   return e.offsetWidth + tolerance < e.scrollWidth;
}

크로스 브라우저 호환성

경우, 사실, 위의 코드와 사용을 시도 console.log의 값을 인쇄 e.offsetWidth하고 e.scrollWidth더 텍스트 잘림이없는 경우에도, 당신은 IE에 다음 사항을 통지합니다,의 값 차이 1px또는 2px경험이있다.

따라서 사용하는 글꼴 크기에 따라 특정 허용 오차를 허용하십시오!


답변

elem.offsetWdith VS ele.scrollWidth 이것은 나를 위해 일한다!
https://jsfiddle.net/gustavojuan/210to9p1/

$(function() {
  $('.endtext').each(function(index, elem) {
    debugger;
    if(elem.offsetWidth !== elem.scrollWidth){
      $(this).css({color: '#FF0000'})
    }
  });
});

답변

이 샘플은 텍스트가 잘린 셀 테이블의 툴팁을 보여줍니다. 테이블 너비를 기준으로 동적입니다.

$.expr[':'].truncated = function (obj) {
    var element = $(obj);

    return (element[0].scrollHeight > (element.innerHeight() + 1)) || (element[0].scrollWidth > (element.innerWidth() + 1));
};

$(document).ready(function () {
    $("td").mouseenter(function () {
        var cella = $(this);
        var isTruncated = cella.filter(":truncated").length > 0;
        if (isTruncated)
            cella.attr("title", cella.text());
        else
            cella.attr("title", null);
    });
});

데모 : https://jsfiddle.net/t4qs3tqs/

모든 버전의 jQuery에서 작동합니다.