Как убрать ненужное пространство между строками и столбцами в таблице?

178

Как убрать лишнее пространство между строками и столбцами в таблице.

Я попытался изменить поля, отступы и различные свойства границ для таблицы и tr и td.

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

Как мне это исправить?

CSS

table {
  border-collapse: collapse;
}

HTML

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">

<head>
  <title>Tera Byte Video Game Creation Camp</title>
  <link rel="stylesheet" type="text/css" href="style.css"></link>
</head>

<body>
  <table class="mytable" align="center">
    <tr class="header">
      <td colspan="3"><img src="images/home_01.png" /></td>
    </tr>
    <tr class="top">
      <td colspan="3"><img src="images/home_02.png" /></td>
    </tr>
    <tr class="link-row">
      <td><img src="images/home_03.png" /></td>
      <td><img src="images/home_04.png" /></td>
      <td><img src="images/home_05.png" /></td>
    </tr>
    <tr class="link-row">
      <td><img src="images/home_07.png" /></td>
      <td><img src="images/home_06.png" /></td>
      <td><img src="images/home_08.png" /></td>
    </tr>
    <tr class="link-row">
      <td><img src="images/home_09.png" /></td>
      <td><img src="images/home_10.png" /></td>
      <td><img src="images/home_11.png" /></td>
    </tr>
    <tr class="link-row">
      <td><img src="images/home_12.png" /></td>
      <td><img src="images/home_13.png" /></td>
      <td><img src="images/home_14.png" /></td>
    </tr>
    <tr class="bottom">
      <td colspan="3"><img src="images/home_15.png" /></td>
    </tr>
  </table>

</body>

</html>
Зак Галант
источник

Ответы:

85

Добавьте этот сброс CSS в ваш код CSS: ( отсюда )

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
    display: block;
}
body {
    line-height: 1;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}

Он будет эффективно сбрасывать CSS, избавляясь от отступов и полей.

Vectran
источник
15
Если вы читаете, есть комментарий: / * таблицам по-прежнему нужно указывать в разметке 'cellspacing = "0" * /
easwee
2
что произойдет, если вы используете много CSS на своей странице, и вы не хотите сбрасывать его?
Семь Земель
Вероятно, лучше всего использовать метод сброса или какой-то фреймворк и строить из него. Однако в этом случае вам придется сбросить каждый стиль, т.е. table {padding: 0px; граница: 0px; коллапс границы: коллапс; и т.д.} .... Ознакомьтесь с quirksmode.org/css/tables.html для получения дополнительной информации.
vectran
Вы можете пропустить многие из них, так как это только для таблиц.
Цай Хаоян
31
Это чрезмерно, не отвечает на вопрос и даже не является полным сбросом. Возможно, выделите соответствующий код, объясните его, а затем предложите использовать сброс.
Сэнди Гиффорд
199

Добавление к ответу vectran: Вы также должны установить cellspacingатрибут в элементе таблицы для кросс-браузерной совместимости.

<table cellspacing="0">

РЕДАКТИРОВАТЬ (ради полноты я расширяю это через 5 лет :):

Internet Explorer 6 и Internet Explorer 7 требовали, чтобы вы устанавливали пространство ячеек непосредственно в качестве атрибута таблицы, иначе расстояние не исчезнет.

Internet Explorer 8 и более поздние версии и все другие версии популярных браузеров - Chrome, Firefox, Opera 4+ - поддерживают интервал между свойствами CSS .

Таким образом, чтобы сделать межбраузерный сброс интервала между ячейками таблицы (с поддержкой IE6 в качестве браузера динозавров), вы можете воспользоваться приведенным ниже примером кода:

table{
  border: 1px solid black;
}
table td {
  border: 1px solid black; /* Style just to show the table cell boundaries */
}


table.no-spacing {
  border-spacing:0; /* Removes the cell spacing via CSS */
  border-collapse: collapse;  /* Optional - if you don't want to have double border where cells touch */
}
<p>Default table:</p>

<table>
  <tr>
    <td>First cell</td>
    <td>Second cell</td>
  </tr>
</table>

<p>Removed spacing:</p>

<table class="no-spacing" cellspacing="0"> <!-- cellspacing 0 to support IE6 and IE7 -->
  <tr>
    <td>First cell</td>
    <td>Second cell</td>
  </tr>
</table>

easwee
источник
68

Это сработало для меня:

#table {
  border-collapse: collapse;
  border-spacing: 0;
}
pagetribe
источник
55

Для изображений в формате td используйте это для изображений:

display: block;

Это удаляет ненужное место для меня

Якоб Бертельсен
источник
9

Просто добавив сверху ответ Иакова, ибо imgв td,

body {line-height: 0;}
img {display: block; vertical-align: bottom;}

Это работает для большинства почтовых клиентов, включая Gmail. Но не внешний вид. Для перспективы вам нужно сделать еще два шага:

table {border-collapse: collapse;}

и установите для каждого tdэлемента одинаковые heightи widthсодержащиеся в нем изображения. Например,

<td width="600" height="80" style="line-height: 80px;">
    <img height="80" src="http://www.website.com/images/Nature_01.jpg" width="600" />
</td>
hexinpeter
источник
8
table 
{
    border-collapse: collapse;
}

свернут все границы, разделяющие столбцы таблицы ...

или попробуйте

<table cellspacing="0" style="border-spacing: 0;">

сделать все интервалы между ячейками до 0 и интервалы между границами 0, чтобы достичь того же.

веселиться!

Аамир Шахзад
источник
1
<table cellspacing="0" border-spacing: 0;>неверная разметка! <table cellspacing="0" style="border-spacing: 0;">было бы правильно
Дирк фон Грюниген
8

Для соответствия стандартам HTML5 добавьте все эти CSS, чтобы убрать все пробелы между изображениями в таблицах:

table { 
    border-spacing: 0;
    border-collapse: collapse;
}
td {
    padding:0px;
}
td img {
    display:block;
}
totallytotallyamazing
источник
5

Попробуй это,

table{
border-collapse: collapse; /* 'cellspacing' equivalent */
}

table td, 
table th{
padding: 0; /* 'cellpadding' equivalent */
}
Ракеш Ваднал
источник
4

установка Cellpadding и cellspacing в 0 удалит ненужное пространство между строками и столбцами ...

Виджай
источник
4

Все, что мне нужно было сделать, это добавить:

line-height: 0px;

в моем

<tr ...>
Анхель Рамирес Исеа
источник
Есть другие ответы, которые предоставляют вопрос ОП, и они были опубликованы некоторое время назад. При публикации ответа, пожалуйста, убедитесь, что вы добавили либо новое решение, либо существенно лучшее объяснение, особенно когда отвечаете на старые вопросы.
help-info.de
1

добавление этой строки в начало файла сработало для меня:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

изменение CSS для установки правильных свойств границы не работало, пока я не добавил строку выше

Альберт с
источник
Это единственная вещь, которая работала на меня! +1 и СПАСИБО! У меня было установлено строгое вместо переходного.
Скотт Биггс
0

Вы пытались удалить TR, у которых есть кольспан, и посмотреть, изменит ли это что-нибудь?

Я испытал colspans и rowspans, чтобы быть довольно противным, когда это сводится к точным проектам стола. Если ваши изображения выглядят хорошо без colspan-TR, я бы начал с создания вложенного набора таблиц.

Кроме того, ваш style.css, кажется, не является полным, может быть, там что-то не так? Я бы хотя бы добавил padding: 0; margin: 0;в таблицу (или в класс "mytable"). Убедитесь, что у ваших изображений тоже нет пробелов и / или границ (например, добавив их img { border: 0; }в таблицу стилей).

Select0r
источник
удаление TR с помощью colspan ничего не делает. добавление отступов и поля тоже ничего не делает
Зак Галант,
0

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

В этом примере SuColTable является классом в таблице.

.SuColTable tr {
    border: none !important;
}

.SuColTable td {
    border-spacing: 0 !important;
    border: none !important;
    margin: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    padding-right: 0 !important;
}


.SuColTable {
    border-collapse: collapse !important;
    border: none !important;
    border-spacing: 0 !important;
    border-collapse: separate !important;
    padding-left: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
// all padding would be padding: 0 !important

Border-collapse, border: none и border-spacing избавляют от строки таблицы / строки / столбца. Запросы заполнения 0 освобождают заполнение от таблицы-контейнера. Я должен был включить! Important в каждом стиле, чтобы он работал, чтобы переопределить стили таблицы контейнера.

У меня есть padding_top, left и bottom (вместо только padding), потому что у меня есть два других класса, которые управляют padding_right.

line-height: 0px;

Строка-высота ноль делает строку на одну строку выше. Если у вас есть несколько строк, они сжимаются в одну строку.

Джордж
источник
-2

table{
  border: 1px solid black;
}
table td {
  border: 1px solid black; /* Style just to show the table cell boundaries */
}


table.no-spacing {
  border-spacing:0; /* Removes the cell spacing via CSS */
  border-collapse: collapse;  /* Optional - if you don't want to have double border where cells touch */
}
<p>Default table:</p>

<table>
  <tr>
    <td>First cell</td>
    <td>Second cell</td>
  </tr>
</table>

<p>Removed spacing:</p>

<table class="no-spacing" cellspacing="0"> <!-- cellspacing 0 to support IE6 and IE7 -->
  <tr>
    <td>First cell</td>
    <td>Second cell</td>
  </tr>
</table>

Ikeanyi kenechukwu
источник
Есть другие ответы, которые предоставляют вопрос ОП, и они были опубликованы некоторое время назад. При публикации ответа, пожалуйста, убедитесь, что вы добавили либо новое решение, либо существенно лучшее объяснение, особенно когда отвечаете на старые вопросы.
help-info.de