Come rimuovere lo spazio indesiderato tra le righe e le colonne nella tabella?


177

Come rimuovo lo spazio aggiuntivo tra le righe e le colonne nella tabella.

Ho provato a cambiare il margine, il riempimento e le varie proprietà del bordo sulla tabella e tr e td.

Voglio che le immagini siano tutte una accanto all'altra come una grande immagine.

Come devo risolvere questo?

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>

Risposte:


84

Aggiungi questo reset CSS al tuo codice CSS: ( Da qui )

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

Ripristinerà efficacemente il CSS, eliminando il riempimento e i margini.


15
C'è un commento se leggi dicendo: / * le tabelle hanno ancora bisogno di 'cellspacing = "0"' nel markup * /
easwee

2
cosa succede se stai usando molti CSS nella tua pagina e non vuoi reimpostarlo?
Sevenearths,

Probabilmente è buona prassi usare un reset o una sorta di framework e costruire da lì. Tuttavia, in questo caso dovrai ripristinare ogni stile, ad es. tabella {padding: 0px; bordo: 0px; confine-collasso: collasso; ecc} .... Scopri quirksmode.org/css/tables.html per ulteriori informazioni.
vectran,

Puoi saltarne molti poiché è solo per i tavoli.
Cai Haoyang,

31
Questo è eccessivo, non risponde alla domanda e non è nemmeno un ripristino completo. Forse isolare il codice rilevante, spiegarlo e quindi suggerire di utilizzare un ripristino.
Sandy Gifford,

198

Aggiunta alla risposta di vectran: è inoltre necessario impostare l' cellspacingattributo sull'elemento tabella per la compatibilità tra browser.

<table cellspacing="0">

MODIFICA (per completezza lo sto espandendo 5 anni dopo :):

Internet Explorer 6 e Internet Explorer 7 richiedevano di impostare la spaziatura cellulare direttamente come attributo di tabella, altrimenti la spaziatura non svanirebbe.

Internet Explorer 8 e versioni successive e tutte le altre versioni dei browser più diffusi - Chrome, Firefox, Opera 4+ - supportano la spaziatura dei bordi delle proprietà CSS .

Quindi, al fine di ripristinare una spaziatura tra le celle della tabella tra browser (supportando IE6 come browser di dinosauro), puoi seguire l'esempio di codice seguente:

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

Questo ha funzionato per me:

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

55

Per le immagini in td, usa questo per le immagini:

display: block;

Ciò rimuove lo spazio indesiderato per me


9

Aggiungendo solo la risposta di Jacob, perché imgin td,

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

Funziona con la maggior parte dei client di posta elettronica, incluso Gmail. Ma non Outlook. Per Outlook, devi fare altri due passi:

table {border-collapse: collapse;}

e imposta ogni tdelemento in modo che abbia le stesse heighte widthle sue immagini contenute. Per esempio,

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

comprime tutti i bordi che separano le colonne della tabella ...

o prova

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

fai tutte le spaziature tra celle su 0 e spaziatura bordo 0 per ottenere lo stesso.

divertiti!


1
<table cellspacing="0" border-spacing: 0;>è un markup non valido! <table cellspacing="0" style="border-spacing: 0;">sarebbe corretto
Dirk von Grünigen il

8

Per HTML5 conforme agli standard aggiungi tutto questo css per rimuovere tutto lo spazio tra le immagini nelle tabelle:

table { 
    border-spacing: 0;
    border-collapse: collapse;
}
td {
    padding:0px;
}
td img {
    display:block;
}

5

Prova questo,

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

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

4

l'impostazione di Cellpadding e cellpacing su 0 rimuoverà lo spazio non necessario tra righe e colonne ...


4

Tutto quello che dovevo fare era aggiungere:

line-height: 0px;

nel mio

<tr ...>

Esistono altre risposte che forniscono la domanda del PO e sono state pubblicate qualche tempo fa. Quando pubblichi una risposta, assicurati di aggiungere una nuova soluzione o una spiegazione sostanzialmente migliore, soprattutto quando rispondi a domande più vecchie.
help-info.de

1

aggiungendo questa riga all'inizio del file ha funzionato per me:

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

la modifica del CSS per impostare le proprietà corrette del bordo non ha funzionato fino a quando non ho aggiunto la riga sopra


Questa è l'unica cosa che ha funzionato per me! +1 e GRAZIE! L'avevo impostato su Strict anziché su Transition.
Scott Biggs,

0

Hai provato a rimuovere i TR che hanno un colspan e vedi se cambia qualcosa?

Ho sperimentato colpanici e rematori di essere piuttosto cattivi quando si tratta di accurati disegni da tavolo. Se le tue immagini sembrano a posto senza i colspan-TR, inizierei da lì e creerei un tavolo nidificato.

Anche il tuo style.css non sembra essere completo, forse c'è qualcosa che non va lì? Almeno aggiungerei padding: 0; margin: 0;alla tabella (o alla classe "mytable"). Assicurati che anche le tue immagini non abbiano spazi e / o bordi (ad es. Aggiungendo img { border: 0; }al tuo foglio di stile).


rimuovere i TR con un colspan non fa nulla. l'aggiunta di imbottitura e margine non fa nulla
Zach Galant,

0

Ho avuto questo problema e nessuno dei suggerimenti di diversi post ha funzionato, li ho provati tutti. Il mio problema è risultato che la tabella che stavo creando è nidificata in un'altra tabella, ereditando sulle sue proprietà. Avevo bisogno di scavalcare la tabella del contenitore.

In questo esempio, SuColTable è la classe nella tabella.

.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

Collapse-border, border: none e border-spacing eliminano la tabella / riga / colonna. Le chiamate di riempimento 0 eliminano il riempimento dalla tabella del contenitore. Ho dovuto includere! Importante in ogni stile perché funzioni, al fine di sovrascrivere gli stili della tabella del contenitore.

Ho padding_top, left e bottom (anziché solo padding) perché ho altre due classi che controllano padding_right.

line-height: 0px;

L'altezza della linea zero rende la riga alta una riga. Se si dispone di più righe, vengono compresse in un'unica riga.


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


Esistono altre risposte che forniscono la domanda del PO e sono state pubblicate qualche tempo fa. Quando pubblichi una risposta, assicurati di aggiungere una nuova soluzione o una spiegazione sostanzialmente migliore, soprattutto quando rispondi a domande precedenti.
help-info.de
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.