Linethrough / зачеркивание всей строки таблицы HTML
после некоторых исследований, я не мог найти ответ на этот вопрос. Там было этой но на самом деле это не ответ на мой вопрос. Я хотел бы "зачеркнуть" полную строку таблицы HTML в CSS, а не только текст в ней. Возможно ли это вообще? Из примера, который я связал, кажется, что стиль tr даже не работает в Firefox. (И в любом случае, текстовое оформление применяется только к тексту afaik)
8 ответов
О да, да!
CSS:
table {
border-collapse: collapse;
}
td {
position: relative;
padding: 5px 10px;
}
tr.strikeout td:before {
content: " ";
position: absolute;
top: 50%;
left: 0;
border-bottom: 1px solid #111;
width: 100%;
}
HTML-код:
<table>
<tr>
<td>Stuff</td>
<td>Stuff</td>
<td>Stuff</td>
</tr>
<tr class="strikeout">
<td>Stuff</td>
<td>Stuff</td>
<td>Stuff</td>
</tr>
<tr>
<td>Stuff</td>
<td>Stuff</td>
<td>Stuff</td>
</tr>
</table>
мой ответ (ниже) сказал, что это невозможно. Я был неправ, как указал @NicoleMorganErickson. Пожалуйста, посмотрите ее ответ (и upvote это!), как это сделать. Короче говоря, вы используете :before
псевдо-класс для создания элемента, который рисует границу по середине ячейки, над содержимым:
table { border-collapse:collapse } /* Ensure no space between cells */
tr.strikeout td { position:relative } /* Setup a new coordinate system */
tr.strikeout td:before { /* Create a new element that */
content: " "; /* …has no text content */
position: absolute; /* …is absolutely positioned */
left: 0; top: 50%; width: 100%; /* …with the top across the middle */
border-bottom: 1px solid #000; /* …and with a border on the top */
}
(оригинал ответа)
нет, невозможно использовать только CSS и разметку семантической таблицы. Как предполагает @JMCCreative, это возможно визуально используя любое количество способов позиционирования строки над вашей строкой.
вместо этого я бы предложил использовать комбинацию color
, background-color
, font-style:italic
и/или text-decoration:line-through
сделать весь ряд, очевидно, разные. (Я бы лично сильно "выцветал" текст до цвета, намного ближе к фону, чем обычный текст, и делал его курсивом.)
самый простой способ-использовать background-image
на tr
и его клетки-потомки (или просто используйте прозрачный background-color
на эти клетки).
HTML-код:
<table>
<thead>
<tr>
<th>Col One</th>
<th>Col Two</th>
<th>Col Three</th>
</tr>
</thead>
<tbody>
<tr>
<td>First row, One-One</td>
<td>First row, One-Two</td>
<td>First row, One-Three</td>
</tr>
<tr class="empty">
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
css:
table {
empty-cells: show;
}
th, td {
width: 6em;
height: 2em;
line-height: 2em;
border: 1px solid #ccc;
}
tr.empty,
tr.empty td {
background: transparent url('http://davidrhysthomas.co.uk/linked/strike.png') 0 50% repeat-x;
}
tr {
background-image: url('');
background-repeat: repeat-x;
background-position: 50% 50%;
}
Я http://www.patternify.com/ для создания 1х1 URL-адрес изображения.
мне нравится Николь Морган Эриксон ответ, но это может вызвать побочные эффекты если вы реализуете его решение дословно. Я добавил несколько небольших настроек, чтобы сохранить это кошерным, ниже... так что мы не глобальное изменение каждой таблицы или каждого td с помощью этого css.
Я также хотел кнопку в строке, чтобы вычеркнуть строку, но я не хотел вычеркивать столбец кнопкой, для видимости. Я просто хотел вычеркнуть все остальное. из ряда. Для этого я сделал так, что каждая колонка, которая хочет быть способной показать вычеркивание, должна объявить такое, также помеченное классом. в этой итерации вам нужно будет пометить таблицу как strike-able, а также пометить каждый td как strike-able; но вы получаете безопасность, не участвуя в каких-либо не-strike-able таблицах, и вы получаете контроль над тем, какие столбцы ударить из.
CSS:
table.strike-able {
border-collapse: collapse;
}
table.strike-able tr td {
position: relative;
padding: 3px 2px;
}
table.strike-able tr th {
position: relative;
padding: 3px 2px;
}
table.strike-able tr.strikeout td.strike-able:before {
content: " ";
position: absolute;
top: 50%;
left: 0;
border-bottom: 2px solid #d9534f;
width: 100%;
}
использование:
<table class="strike-able" id="Medications" data-item-count="@Model.Medications.Count">
<tr>
<th>
Some Column
</th>
<th>
Command Column
</th>
</tr>
<tr class="strikeout">
<td class="strike-able"></td>
<td>Button that Toggles Striking Goes Here (active)</td>
</tr>
<tr>
<td class="strike-able"></td>
<td>Button that Toggles Striking Goes Here</td>
</tr>
</table>
наконец, поскольку я использую это с Bootstrap и рассматриваю удаление как опасную вещь, я отформатировал цвета немного, чтобы соответствовать моему использованию.
@NicoleMorganErickson, мне нравится ваш ответ, но я не мог заставить вычеркнуть только примененную строку. Кроме того, мне нужно было применить несколько строк, поэтому я изменил ваше решение в один класс.
CSS:
tr.strikeout td:before {
content: " ";
position: absolute;
display: inline-block;
padding: 5px 10px;
left: 0;
border-bottom: 1px solid #111;
width: 100%;
}
Да, вы можете. В первой ячейке строки вы создаете div, содержащий HR. Переместите div влево и укажите его ширину в % от содержащегося в нем элемента, в данном случае ячейки таблицы. Он будет растягиваться так широко, как вы хотите, через ячейки таблицы в этой строке, даже за пределами ширины таблицы, если вы хотите.
это работает для меня:
<style>
.strikeThrough {
height:3px;
color:#ff0000;
background-color:#ff0000;
}
.strikeThroughDiv {
float:left;
width:920%;
position:relative;
top:18px;
border:none;
}
</style>
<table width="900" border="1" cellspacing="0" cellpadding="4">
<tr valign="bottom">
<td>
<div class="strikeThroughDiv"><hr class="strikeThrough"/></div>
One
</td>
<td>
<label for="one"></label>
<input type="text" name="one" id="one" />
</td>
<td>
<label for="list"></label>
<select name="list" id="list">
<option value="One">1</option>
<option value="Two">2</option>
<option value="Three" selected>3</option>
</select>
</td>
<td>
Four
</td>
<td>
Five
</td>
</tr>
</table>
для управления шириной строки необходимо указать ширину ячейки таблицы, содержащей HR. Для укладки HR элементы говорят, что вы не должны делать его меньше 3px в высоту.
Как насчет абсолютно позиционирования <hr />
элемент overtop строки. В зависимости от того, насколько статичным или динамичным это должно быть, это может быть очень быстрый/простой способ или намного сложнее.