Як видалити небажаний пробіл між рядками та стовпцями таблиці?


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, позбувшись прокладки та поля.


15
Є коментар, якщо ви читаєте: / * таблиці все ще потребують 'cellpacing = "0"' у розмітці * /
easwee

2
що станеться, якщо ви використовуєте на своїй сторінці багато css і не хочете її скинути?
Sevenearths

Мабуть, найкраща практика використовувати скидання чи якусь структуру та будувати звідти. Однак у цьому випадку вам доведеться скинути кожен стиль, тобто. стіл {padding: 0px; межа: 0px; кордон-колапс: колапс; тощо} .... Отримайте замовлення quirksmode.org/css/tables.html для отримання додаткових відомостей.
вектран

Ви можете пропустити їх багато, оскільки це лише для столів.
Чай Хаоян

31
Це надмірно, не відповідає на питання і навіть не є повним скиданням. Можливо, виділіть відповідний код, поясніть його, а потім запропонуйте скористатися скиданням.
Сенді Гіффорд

198

Додавання до відповіді вектора: Вам також потрібно встановити cellspacingатрибут на елементі таблиці для сумісності між браузерами.

<table cellspacing="0">

EDIT (задля повноти я розширюю це через 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>


68

Це працювало для мене:

#table {
  border-collapse: collapse;
  border-spacing: 0;
}

55

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

display: block;

Це видаляє для мене небажаний простір


9

Просто додавши до відповіді Якова, бо imgв td,

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

Це працює для більшості клієнтів електронної пошти, включаючи Gmail. Але не Outlook. Для перспектив потрібно зробити ще два кроки:

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>

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;
}

5

Спробуйте це,

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

table td, 
table th{
padding: 0; /* 'cellpadding' equivalent */
}

4

якщо встановити Cellpadding та Cellpacing на 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 і ДЯКУЙТЕ! У мене це було встановлено на Strict замість перехідного.
Скотт Біггс

0

Ви спробували видалити ТР, на яких є шпилька, і побачите, чи це щось змінить?

Я пережив кольсоподібні та гребні лопати досить неприємні, коли справа доходить до точних конструкцій столів. Якщо ваші зображення виглядають нормально без кольчужних TR, я б почав звідти і будував вкладений набір наборів.

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


видалення TR з колпаном нічого не робить. додавання прокладки та маржі також нічого не робить
Зак Галант

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

Кордон-згортання, кордон: жодне та проміжки між кордонами позбавляються від таблиці таблиці / рядків / стовпців. 0 викликів прокладки позбавляють прокладки з таблиці контейнерів. Мені довелося включати важливе значення для кожного стилю для його роботи, щоб перекрити стилі таблиці контейнерів.

У мене padding_top, зліва і знизу (замість лише 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>


Є й інші відповіді, які забезпечують питання ОП, і вони були опубліковані деякий час тому. Опублікувавши відповідь, будь ласка, переконайтесь, що ви додали або нове рішення, або істотно краще пояснення, особливо, відповідаючи на старі питання.
help-info.de
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.