Вопрос по html, css, css3 – Почему многоточие CSS не работает в ячейке таблицы?

130

Рассмотрим следующий пример: (живое демо здесь)

HTML:

<code><table>
  <tbody>
    <tr><td>Hello Stack Overflow</td></tr>
  </tbody>
</table>
</code>

CSS:

<code>td {
  border: 1px solid black;
  width: 50px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
</code>

JS:

<code>$(function() {
  console.log("width = " + $("td").width());
});
</code>

Выход:width = 139и многоточие не появляется.

Что мне здесь не хватает?

возможный дубликатCSS text-overflow in a table cell? BoltClock♦
Я все еще предпочитаю ответы, перечисленные на этой странице, однако. Florian Margaine
@FlorianMargaine На самом деле, другой вопрос предоставляет обходной путь: поместите div в ячейку с желаемой шириной. Mr Lister
width а такжеheight на столе ячейки всегда используются какminimal ширина и высота. Ячейки таблицы разные! Mr Lister
Каким-то образом дублировать, но ответ не дает обходного пути (как это делает Арлен Кусс). Florian Margaine

Ваш Ответ

10   ответов
68

td { display: block; } но это побеждает цель использования стола.

Ты можешь использоватьtable { table-layout: fixed; } но, может быть, вы хотите, чтобы он вел себя по-другому для некоторых столбцов.

Таким образом, лучший способ добиться того, чего вы хотите, - это обернуть ваш текст в<div> и применить свой CSS к<div> (не к<td>) как это :

td {
  border: 1px solid black;
}
td > div {
  width: 50px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
Это на самом деле лучшее решение, которое я видел на многоточии в таблицах.
Это самый простой метод, который я видел, и он действительно работает в IE8.
1

та, я обнаружил, что отключенный и стилизованный ввод выглядит лучше и все же позволяет пользователю просматривать и выбирать всю строку, если это необходимо.

<input disabled='disabled' style="border: 0; padding: 0; margin: 0" />

Выглядит как текстовое поле, но выделяется цветом, поэтому удобнее для пользователя

Это не удобно для пользователя, потому что при использовании вспомогательных технологий это неправильно воспринимается как ввод, и поэтому пользователь думает, что он может что-то ввести. Неверно использовать семантику элементов.
15
Demo page

довлетворительных результатов. каждый<th> который должен иметь возможность обрезки текста, должен иметь внутренний элемент обтекания, который оборачивает содержимое<th> разрешатьtext-overflow работать.

Тогда настоящая хитрость заключается в том, чтобы установитьmax-width (на<th>) вvw единицы.

Это эффективно заставит ширину элемента быть «связанной»; на ширину области просмотра (окно браузера) и приведет к отзывчивому контенту. Установитьvw единиц к удовлетворительной стоимости, необходимой.

Minimal CSS:
th{ max-width:10vw; }

th > .wrap{ 
   text-overflow:ellipsis;
   overflow:hidden;
   white-space:nowrap;
}
Here's a runnable demo:

table {
  font: 18px Arial;
  width: 40%;
  margin: 1em auto;
  color: #333;
  border: 1px solid rgba(153, 153, 153, 0.4);
}

table td, table th {
  text-align: left;
  padding: 1.2em 20px;
  white-space: nowrap;
  border-left: 1px solid rgba(153, 153, 153, 0.4);
}

table td:first-child, table th:first-child {
  border-left: 0;
}

table th {
  border-bottom: 1px solid rgba(153, 153, 153, 0.4);
  font-weight: 400;
  text-transform: uppercase;
  max-width: 10vw;
}

table th > .wrap {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
<table>
    <thead>
        <tr>
            <th>
                <div class="wrap" title="Some long title">Some long title</div>
            </th>
            <th>
                <div class="wrap">Short</div>
            </th>
            <th>
                <div class="wrap">medium one</div>
            </th>
            <th>
                <div class="wrap" title="endlessly super long title which no developer likes to see">endlessly super long title which no developer likes to see</div>
            </th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>-</td>
            <td>-</td>
            <td>-</td>
            <td>very long text here</td>
        </tr>
    </tbody>
</table>

34

max-width вместоwidthтаблица по-прежнему будет автоматически вычислять ширину.

Работает даже вie11 (с режимом совместимости ie8).

td.max-width-50 {
  border: 1px solid black;
  max-width: 50px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
<table>
  <tbody>
    <tr>
      <td class="max-width-50">Hello Stack Overflow</td>
    </tr>
    <tr>
      <td>Hello Stack Overflow</td>
    </tr>
    <tr>
      <td>Hello Stack Overflow</td>
    </tr>
  </tbody>
</table>

jsfiddle.

Хорошо подмечено. Это, вероятно, лучше всего использоватьboth, так что элемент имеет фиксированную ширину. В противном случае это может быть короче, если содержание позволяет это.
73

Это также важно поставить

table-layout:fixed;

Что касается таблицы, то она хорошо работает и в IE9 (если вы используете max-width).

это также гарантирует, что переполнение текста работает в адаптивных макетах
Это именно то, что мне было нужно. У меня ширина стола 100%. И все столбцы кроме одного с фиксированной шириной. Это позволяет последнему столбцу занимать столько места, сколько осталось.
95

Видимо, добавив:

td {
  display: block; /* or inline-block */
}

решает проблему также.

Другое возможное решение - установитьtable-layout: fixed; для таблицы, а также установить егоwidth, Например:http://jsfiddle.net/fd3Zx/5/

Именно так. Элементы сdisplay: table-cell (по умолчанию дляtd элементы) не принимают ширину.
display: block; своего рода побеждает цель использования стола. мне нравитсяtable-layout: fixed; вариант, он работал хорошо для меня.
Иногда я хочу добавить* {display: block} на мои таблицы стилей ...
table-layout:fixed распределяет ширину столбцов менее умным способом. Есть ли другой вариант, который будет назначать ширину столбца таким же образомtable-layout: normal и все же отображать многоточие правильно?
3

так как у меня была эта проблема, и ни один из других ответов здесь не дал желаемого эффекта, которого я хотел. Поэтому вместо этого я использовал список. Теперь, с точки зрения семантики, информацию, которую я выводил, можно было рассматривать как в виде табличных данных, так и в виде перечисленных данных.

В итоге я сделал следующее:

<ul>
    <li class="group">
        <span class="title">...</span>
        <span class="description">...</span>
        <span class="mp3-player">...</span>
        <span class="download">...</span>
        <span class="shortlist">...</span>
    </li>
    <!-- looped <li> -->
</ul>

Так в основномul являетсяtable, li являетсяtr, а такжеspan являетсяtd.

Затем в CSS я установилspan элементы, которые будутdisplay:block; а такжеfloat:left; (Я предпочитаю эту комбинациюinline-block как это будет работать в более старых версиях IE, чтобы очистить эффект с плавающей точкой, смотрите:http://css-tricks.com/snippets/css/clear-fix/) а также иметь эллипсы:

span {
    display: block;
    float: left;
    width: 100%;

    // truncate when long
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

Тогда все, что вам нужно сделать, это установитьmax-widths ваших пролетов, и это даст списку вид таблицы.

0

какие они есть. Просто оберните содержимое внутри TD с помощью диапазона, к которому применен усеченный CSS.

/* CSS */
.truncate {
    width: 50px; /*your fixed width */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block; /* this fixes your issue */
}

<!-- HTML -->
<table>
    <tbody>
        <tr>
            <td>
                <span class="truncate">
                    Table data to be truncated if it's too long.
                </span>
            </td>
        </tr>
    </tbody>
</table>
0

этот ответ), вы можете установить max-width в div:

function so_hack(){}

function so_hack(){} http://jsfiddle.net/fd3Zx/754/ function so_hack(){}

function so_hack(){}

Примечание: 100% не работает, но 99% работает в FF. Другие современные браузеры не нуждаются в глупых взломах div.

td {
  border: 1px solid black;
    padding-left:5px;
    padding-right:5px;
}
td>div{
    max-width: 99%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;

}
1

box-sizing собственность вашего csstd элементы. У меня была проблема с шаблоном CSS, который устанавливает егоborder-box значение. Вам нужно установитьbox-sizing: content-box.

Похожие вопросы