Невозможно поместить поле для тега <td>без атрибута CSS или ячейки - PullRequest
31 голосов
/ 09 декабря 2010

По какой-то причине я не смог получить ни одной ячейки таблицы, чтобы между ними было поле. Я хочу, чтобы ячейки таблицы имели серый фоновый цвет (на белом фоне страницы), чтобы он выглядел как плитки с белым между ними.

Я пробовал в HTML,

<table cellspacing="3">

Также в CSS,

table td {
    margin:3px;
}

Ничего не работает. Клетки все еще склеены, как один большой серый шарик. Я скучаю по чему-то очень основному здесь?

Вот фактический код:

<table width="100%" cellspacing="3">
    <tr>
        <th>Document Number</th>
        <th>BP Reference No.</th>
        <th>Posting Date</th>
        <th>Posting Week</th>
        <th>Customer/Vendor Code</th>
        <th>Customer/Vendor Name</th>
        <th>Item No.</th>
        <th>Item/Service Description</th>
        <th>Item Group</th>
        <th>Warehouse Code</th>
        <th>Remaining Open Quantity</th>
        <th>Line No.</th>
        <th>Sales Employee Name</th>
        <th>Stock</th>
        <th>Fill Rate</th>
        <th>1046</th>
        <th>1047</th>
        <th>1048</th>
        <th>1049</th>
        <th>1050</th>
        <th>1051</th>
        <th>1052</th>
        <th>1053</th>
        <th>1054</th>
        <th></th>
    </tr>
    <tr>
        <td>17272</td>
        <td>2244100</td>
        <td>5/24/2010</td>
        <td>22</td>
        <td>NYST</td>
        <td>NYSTROM INC.</td>
        <td>NYM118SX26DSTKS01</td>
        <td>Nystrom, Mort. 1-1/8'', Schl C~K, US26D, ST cam, 5pin, KS #43758</td>
        <td>Mort Cylinders</td>
        <td>US1</td>
        <td>1000</td>
        <td>3</td>
        <td>KRE Management 1</td>
        <td>0</td>
        <td>100</td>
        <td>1000</td>
        <td>0</td>
        <td>0</td>
        <td>0</td>
        <td>0</td>
        <td>0</td>
        <td>0</td>
        <td>0</td>
        <td>0</td>
        <td></td>
    </tr>
</table>

Ответы [ 7 ]

82 голосов
/ 14 апреля 2011

Если у кого-то все еще есть эта проблема, попробуйте это в вашей таблице стилей CSS:

table {
  border-collapse: separate;
  border-spacing: 10px 5px;
}

Значения для расстояния между границами являются двумя измерениями длины. Горизонтальный значение идет первым и применяется между столбцами. Второе измерение применяется между рядами.

Если вы укажете одно значение, оно будет использоваться как по горизонтали, так и по вертикали. По умолчанию установлено значение 0, в результате чего границы на внутренней сетке таблицы удваиваются.

7 голосов
/ 09 декабря 2010

Если вы используете сброс CSS в начале таблицы стилей, проверьте, имеет ли он следующий код.

table {
  border-collapse: collapse;
}

В этом случае попробуйте переопределить его с помощью:

border-collapse: separate;
4 голосов
/ 02 мая 2016

сделать стиль тд с блоком.Попробуйте это,

<table width="100%" border="0" cellpadding="2" cellspacing="1">
  <tbody>
    <tr>
      <td class="SlateGridDataError">Please Re-enter login information</td>
    </tr>
  </tbody>
</table>

.SlateGridDataError {
    border-radius: 2px;
    display: block;
    font-size: 14px;
    color: #999999;
    display:block;
    border: 1px solid #dd3c39;
    border-left: 5px solid #dd3c39;
    padding: 12px 5px;
    margin-bottom: 20px;
    cursor: default;
    outline: none;
}
0 голосов
/ 16 августа 2014

Попробуйте добавить тд между двумя ТД, которые вы хотите иметь на полях.Установите, чтобы он не имел фона (только не ставьте «background: кое-что;») и имел желаемую ширину.Если вы хотите поместить поле между двумя TR, просто добавьте еще один tr между ними и установите значение td с высотой, которую вы хотите иметь для поля.Вы даже можете использовать один и тот же класс для TD и установить CSS только один раз.

0 голосов
/ 18 мая 2013

Так что я нашел простой способ решить проблему без проблем

допустим, у вас есть

<tr><td>This is an example</td></tr>

Поместите инкапсулируйте все данные в тег

, как это

<tr><td><p>This is an example</p></td></tr>

, а затем присвойте тегу

поле слева от любого значения, например,

<tr><td><p style="margin-left:4px;">This is an example</p></td></tr>

Это делает магию для меня без каких-либо хлопот

0 голосов
/ 22 августа 2011

Это грубое исправление, но оно работает.

Если вы создаете <table> с полем нужного вам размера ... содержащего ваш существующий, оба с использованием того же фона или цвета, которые вы можете установитьполе внешней таблицы должно быть тем, что вы хотите.

Если у вас есть серия <TD> элементов, создайте <table> внутри <TD>, который вы хотите иметь, и снова убедитесь, чточто и внешний <table>, и внутренний <TD> имеют одинаковый фон или цвет.

пример из моего блога по адресу http://harrolds.blogspot.com, в который встроен скрипт для отображения цитат ...

Основной стол:

<table width="100%" bgcolor="lightblue" border=1>
<tbody>
  <tr>
    <td align="left" width="160"><span style="font-family:Times New Roman;font-size: -1;"><small><a href="http://en.wikipedia.org/wiki/Zell_Miller" target="_new">Sen. Zell Miller</a> <small>(D-GA) RNC'04</small></small></span><br /><object width="120" height="106"><param name="movie" value="http://www.youtube-nocookie.com/v/b4GqdfRJf5E&amp;hl=en&amp;fs=1&amp;border=1" /><param name="allowFullScreen" value="true" /><param name="allowscriptaccess" value="always" /><embed src="http://www.youtube-nocookie.com/v/b4GqdfRJf5E&hl=en&fs=1&border=1" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="120" height="106"></embed></object><br /><font size="-1"><span style="color: blue; font-family: "sylfaen";><a href="http://www.harrold.org/rfhextra/support_our_Troops.html" target="_new"><b><small>Liberators &amp; Defenders</small></b></a></span></font> 
    </td>

    <td background="http://harrold.org/rfhextra/images/bgparchmentlight.jpg">
      <table border=0>
        <tr>
          <td background="http://harrold.org/rfhextra/images/bgparchmentlight.jpg"><script language="javascript" src="http://www.harrold.org/rfhextra/quote.js" type="text/javascript"></script>
          </td>
        </tr>
      </table>
    </td>

    <td align="right"><a href="http://www.cafepress.com/rightwingstuff" target="_new"><small><small>RightWingStuff</small></small></a><br /><a href="http://www.gadsdenandculpeper.com/" target="_new"><img src="http://harrold.org/rfhextra/images/GadsdenFlag98x130.gif" width="98" height="130" alt="link source  http://www.cafepress.com/rightwingstuff" border="0" /></a>
    </td>
  </tr>
</tbody>
</table>
0 голосов
/ 09 декабря 2010

Я думаю, cellspacing принимает цвет, такой же, как цвет фона таблицы.
Итак, у вас есть два варианта:
1. Примените цвет фона к td с, а не к <table>.
2. Возможно, вы захотите использовать белую рамку (border для <td> с border-collapse: collapse для таблицы)

...