テーブルの行と列の間の不要なスペースを削除するにはどうすればよいですか?


177

テーブルの行と列の間の余分なスペースを削除するにはどうすればよいですか。

テーブルとtrおよびtdのマージン、パディング、およびさまざまな境界線プロパティを変更してみました。

すべての画像を1つの大きな画像のように並べて配置したい。

どうすれば修正できますか?

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>

回答:


84

この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
/ *テーブルはマークアップに 'cellspacing = "0"が引き続き必要* /
easwee

2
ページで多くのcssを使用していて、リセットしたくない場合はどうなりますか?
セブンアース

おそらくリセットまたは何らかのフレームワークを使用して、そこからビルドするのがベストプラクティスです。ただし、この場合は各スタイルをリセットする必要があります。テーブル{パディング:0px; ボーダー:0px; border-collapse:折りたたみ。など} ....チェックアウトquirksmode.org/css/tables.html多くのため。
vectran 2011年

それはテーブルのためだけなので、それらの多くをスキップできます。
2015年

31
これは過度であり、質問に答えず、完全にリセットすることもできません。おそらく、関連するコードを分離し、それを説明してから、リセットの使用を提案します。
Sandy Gifford 2016

198

vectranの答えに追加:cellspacingブラウザー間の互換性のためにtable要素に属性を設定する必要もあります。

<table cellspacing="0">

編集(完全を期すために、この5年後に拡張します:):

Internet Explorer 6およびInternet Explorer 7では、cellspacingをテーブル属性として直接設定する必要がありました。そうしないと、間隔は消えません。

Internet Explorer 8以降のバージョン、およびその他のすべての一般的なブラウザー(Chrome、Firefox、Opera 4+)は、CSSプロパティborder-spacingをサポートしています。

したがって、クロスブラウザーテーブルのセル間隔をリセットする(恐竜ブラウザーとして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;
}


9

ちょうどのために、ヤコブの答えの上に追加することimgtd

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

これは、Gmailを含むほとんどのメールクライアントで機能します。しかしOutlookではありません。Outlookでは、さらに2つの手順を実行する必要があります。

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;">正解です
ダークフォングリューニゲン2014年

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とCellspacingを0に設定すると、行と列の間の不要なスペースが削除されます...


3

私がしなければならなかったすべては追加することでした:

line-height: 0px;

私の中

<tr ...>

OPの質問を提供する他の回答があり、それらはしばらく前に投稿されました。回答を投稿するときは、特に古い質問に回答する場合は、新しいソリューションまたは大幅に優れた説明を追加してください。
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とありがとうございます。トランジショナルではなくストリクトに設定しました。
スコットビッグス2015年

0

colspanのあるTRを削除して、それが何か変更されるかどうかを確認しましたか?

colspansとrowspansは、正確なテーブル設計になるとかなり厄介であることがありました。colspan-TRがなくても画像が正常に見える場合は、そこから始めて、ネストされたテーブルセットを作成します。

また、あなたのstyle.cssは完全ではないようです、おそらく何か問題がありますか?少なくともpadding: 0; margin: 0;テーブル(または「mytable」クラス)に追加します。また、画像にスペースや境界線がないことimg { border: 0; }を確認してください(スタイルシートに追加するなど)。


colspanでTRを削除しても何も起こりません。パディングとマージンを追加しても何も起こりません
Zach Galant

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_rightを制御する他の2つのクラスがあるため、(paddingのみではなく)padding_top、left、bottomがあります。

line-height: 0px;

行の高さが0の場合、行の高さが1行になります。複数の行がある場合、それらは1行に圧縮されます。


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


OPの質問を提供する他の回答があり、それらはしばらく前に投稿されました。回答を投稿するときは、特に古い質問に回答する場合は、新しいソリューションまたは大幅に優れた説明を追加してください。
help-info.de
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.