【问题标题】:How to remove unwanted space between rows and columns in table?如何删除表格中行和列之间不需要的空间?
【发布时间】:2011-01-17 18:35:27
【问题描述】:

如何去除表格中行和列之间的多余空间。

我已尝试更改表格以及 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>

【问题讨论】:

    标签: html css html-table


    【解决方案1】:

    您是否尝试过删除具有 colspan 的 TR 并查看它是否有任何变化?

    当涉及到准确的表格设计时,我曾经历过 colspans 和 rowspans 非常讨厌。如果您的图像在没有 colspan-TR 的情况下看起来还不错,我会从那里开始构建一个嵌套表集。

    另外你的 style.css 好像不完整,可能有什么问题?我至少会将padding: 0; margin: 0; 添加到表中(或添加到“mytable”类)。 确保您的图片也没有空格和/或边框(例如,通过在样式表中添加 img { border: 0; })。

    【讨论】:

    • 用 colspan 删除 TR 没有任何作用。添加填充和边距也无济于事
    【解决方案2】:

    将 Cellpadding 和 cellspacing 设置为 0 将删除行和列之间不必要的空间...

    【讨论】:

      【解决方案3】:

      将此 CSS 重置添加到您的 CSS 代码中:(From here)

      /* 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,摆脱填充和边距。

      【讨论】:

      • 如果你读到有一条评论说: /* 表在标记中仍然需要 'cellspacing="0"' */
      • 如果您在页面中使用了大量的 CSS 并且您不想重置它会发生什么?
      • 使用重置或某种框架并从那里构建可能是最佳实践。但是在这种情况下,您将不得不重置每种样式,即。表{填充:0px;边框:0px;边框折叠:折叠;等}....结帐quirksmode.org/css/tables.html了解更多信息。
      • 你可以跳过很多,因为它只适用于表格。
      • 这太过分了,没有回答问题,甚至不是完全重置。也许隔离相关代码,解释它,然后建议使用重置。
      【解决方案4】:

      添加到 vectran 的答案:您还必须在 table 元素上设置 cellspacing 属性以实现跨浏览器兼容性。

      <table cellspacing="0">
      

      编辑(为了完整起见,我将在 5 年后对其进行扩展:):

      Internet Explorer 6Internet 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>

      【讨论】:

        【解决方案5】:

        这对我有用:

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

        【讨论】:

          【解决方案6】:

          对于 td 中的图像,将其用于图像:

          display: block;
          

          这为我删除了不需要的空间

          【讨论】:

            【解决方案7】:

            试试这个,

            table{
            border-collapse: collapse; /* 'cellspacing' equivalent */
            }
            
            table td, 
            table th{
            padding: 0; /* 'cellpadding' equivalent */
            }
            

            【讨论】:

              【解决方案8】:
              table 
              {
                  border-collapse: collapse;
              }
              

              将折叠分隔表格列的所有边框...

              或者试试

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

              将所有单元格间距设置为 0,边框间距设置为 0 以达到相同效果。

              玩得开心!

              【讨论】:

              • &lt;table cellspacing="0" border-spacing: 0;&gt; 是无效标记! &lt;table cellspacing="0" style="border-spacing: 0;"&gt; 是正确的
              【解决方案9】:

              对于符合标准的 HTML5,添加所有这些 css 以删除表格中图像之间的所有空间:

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

              【讨论】:

                【解决方案10】:

                将此行添加到文件的开头对我有用:

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

                修改 css 以设置正确的边框属性在我添加上述行之前不起作用

                【讨论】:

                • 这是唯一对我有用的东西! +1,谢谢!我将其设置为严格而不是过渡。
                【解决方案11】:

                只需在 Jacob 的答案之上添加 img in td

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

                这适用于大多数电子邮件客户端,包括 Gmail。但不是 Outlook。 对于 Outlook,您需要多做两步:

                table {border-collapse: collapse;}
                

                并将每个td 元素设置为与其包含的图像具有相同的heightwidth。例如,

                <td width="600" height="80" style="line-height: 80px;">
                    <img height="80" src="http://www.website.com/images/Nature_01.jpg" width="600" />
                </td>
                

                【讨论】:

                  【解决方案12】:

                  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 的问题,它们是前段时间发布的。发布答案时,请确保添加新的解决方案或更好的解释,尤其是在回答较旧的问题时。
                  【解决方案13】:

                  我所要做的就是添加:

                  line-height: 0px;
                  

                  在我的

                  <tr ...>
                  

                  【讨论】:

                  • 还有其他答案提供了 OP 的问题,它们是前段时间发布的。发布答案时,请确保添加新的解决方案或更好的解释,尤其是在回答较旧的问题时。
                  【解决方案14】:

                  我遇到了这个问题,几个帖子的建议都没有奏效,我都试过了。我的问题原来是我创建的表嵌套在另一个表中,继承了它的属性。我需要覆盖容器表。

                  在本例中,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 去掉了table/row/column 行。填充 0 调用从容器表中删除填充。我必须在每种样式中都包含 !important 才能使其正常工作,以便覆盖容器表样式。

                  我有 padding_top、left 和 bottom(而不仅仅是 padding),因为我还有另外两个控制 padding_right 的类。

                  line-height: 0px;
                  

                  行高为零使行高一行。如果您有多行,则将它们压缩为一行。

                  【讨论】: