Como remover o espaço indesejado entre linhas e colunas na tabela?

177

Como removo o espaço extra entre as linhas e colunas da tabela.

Tentei alterar a margem, o preenchimento e várias propriedades da borda na tabela e tr e td.

Quero que as fotos fiquem bem próximas umas das outras para parecer uma grande imagem.

Como devo corrigir isso?

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>
Zach Galant
fonte

Respostas:

84

Adicione esta redefinição CSS ao seu código CSS: ( daqui )

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

Ele redefinirá o CSS efetivamente, eliminando o preenchimento e as margens.

vectran
fonte
15
Há um comentário se você ler dizendo: / * as tabelas ainda precisam de 'cellpacing = "0"' na marcação * /
easwee
2
o que acontece se você estiver usando muito css na sua página e não quiser redefini-lo?
Sevenearths 18/10/11
Provavelmente, é uma boa prática usar uma redefinição ou algum tipo de estrutura e construir a partir daí. No entanto, neste caso, você terá que redefinir cada estilo, ou seja. tabela {padding: 0px; borda: 0px; colapso da fronteira: colapso; etc} .... Confira quirksmode.org/css/tables.html para saber mais.
perfil completo
Você pode pular muitos deles, já que é apenas para as mesas.
Cai Haoyang
31
Isso é excessivo, não responde à pergunta e nem é uma redefinição completa. Talvez isole o código relevante, explique-o e sugira o uso de uma redefinição.
Sandy Gifford
198

Adicionando à resposta do vectran: Você também deve definir o cellspacingatributo no elemento da tabela para compatibilidade entre navegadores.

<table cellspacing="0">

EDIT (por uma questão de exaustividade, estou expandindo isso 5 anos depois :):

O Internet Explorer 6 e o Internet Explorer 7 exigem que você defina o espaçamento entre células diretamente como um atributo da tabela, caso contrário, o espaçamento não desaparecerá.

O Internet Explorer 8 e versões posteriores e todas as outras versões de navegadores populares - Chrome, Firefox, Opera 4+ - oferecem suporte ao espaçamento entre bordas da propriedade CSS .

Portanto, para redefinir o espaçamento das células da tabela entre navegadores (suportando o IE6 como um navegador dinossauro), você pode seguir o exemplo de código abaixo:

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

Isso funcionou para mim:

#table {
  border-collapse: collapse;
  border-spacing: 0;
}
pagetribe
fonte
55

Para imagens em td, use isto para imagens:

display: block;

Isso remove o espaço indesejado para mim

Jacob Bertelsen
fonte
9

Apenas adicionando em cima da resposta de Jacob, para imgdentro td,

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

Isso funciona para a maioria dos clientes de email, incluindo o Gmail. Mas não o Outlook. Para o Outlook, você precisa executar mais duas etapas:

table {border-collapse: collapse;}

e defina todos os tdelementos para que tenham as mesmas heighte widthcomo imagens contidas. Por exemplo,

<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
fonte
8
table 
{
    border-collapse: collapse;
}

recolherá todas as bordas que separam as colunas da tabela ...

ou tente

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

faça todo o espaçamento entre células para 0 e espaçamento entre bordas 0 para obter o mesmo.

divirta-se!

Aamir Shahzad
fonte
1
<table cellspacing="0" border-spacing: 0;>marcação inválida! <table cellspacing="0" style="border-spacing: 0;">estaria correto
Dirk von Grünigen
8

Para padrões compatíveis com HTML5, adicione todo esse CSS para remover todo o espaço entre as imagens nas tabelas:

table { 
    border-spacing: 0;
    border-collapse: collapse;
}
td {
    padding:0px;
}
td img {
    display:block;
}
totalmente incrível
fonte
5

Tente isso,

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

table td, 
table th{
padding: 0; /* 'cellpadding' equivalent */
}
Rakesh Vadnal
fonte
4

definir Cellpadding e cellpacing como 0 removerá o espaço desnecessário entre linhas e colunas ...

Vijay
fonte
3

Tudo o que eu precisava fazer era adicionar:

line-height: 0px;

no meu

<tr ...>
Ángel Ramírez Isea
fonte
Existem outras respostas que fornecem a pergunta do OP e foram publicadas há algum tempo. Ao postar uma resposta, adicione uma nova solução ou uma explicação substancialmente melhor, especialmente ao responder a perguntas mais antigas.
help-info.de
1

adicionar esta linha ao início do arquivo funcionou para mim:

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

modificar o css para definir as propriedades apropriadas da borda não funcionou até eu adicionar a linha acima

Albert s
fonte
Esta é a única coisa que funcionou para mim! +1 e OBRIGADO! Eu tinha definido como Estrito em vez de transitório.
Scott Biggs
0

Você já tentou remover os TRs que possuem um colspan e ver se isso muda alguma coisa?

Eu experimentei colspans e rowpans bastante desagradáveis ​​quando se trata de designs precisos de tabelas. Se suas imagens parecerem boas sem os colspan-TRs, eu começaria a partir daí e criaria um conjunto de tabelas aninhado.

Além disso, seu style.css não parece estar completo, talvez haja algo errado aí? Eu pelo menos adicionaria padding: 0; margin: 0;à tabela (ou à classe "mytable"). Certifique-se de que suas imagens também não possuem espaços e / ou bordas (por exemplo, adicionando img { border: 0; }à sua folha de estilo).

Select0r
fonte
remover os TRs com um colspan não faz nada. adicionando o preenchimento e margem não faz nada quer
Zach Galant
0

Eu tive esse problema e nenhuma das sugestões de várias postagens funcionou, tentei todas elas. Meu problema acabou sendo que a tabela que eu estava criando está aninhada em outra tabela, herdando suas propriedades. Eu precisava substituir a tabela de contêineres.

Neste exemplo, SuColTable é uma classe na tabela.

.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

O colapso de borda, border: none e espaçamento de borda se livram da tabela / linha / linha de coluna. As chamadas 0 de preenchimento eliminam o preenchimento da tabela de contêineres. Eu tive que incluir! Important em todos os estilos para que ele funcionasse, a fim de substituir os estilos de tabela de contêineres.

Eu tenho padding_top, esquerda e parte inferior (em vez de apenas preenchimento) porque tenho outras duas classes que controlam o padding_right.

line-height: 0px;

A altura da linha zero torna a linha uma linha alta. Se você tiver várias linhas, elas serão compactadas em uma linha.

George
fonte
-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
fonte
Existem outras respostas que fornecem a pergunta do OP e foram publicadas há algum tempo. Ao postar uma resposta, adicione uma nova solução ou uma explicação substancialmente melhor, especialmente ao responder a perguntas mais antigas.
help-info.de