テーブルの行と列の間の余分なスペースを削除する方法.
私はテーブルのマージン、パディング、そしてさまざまなボーダープロパティを変更してみました、そして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>
この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をリセットし、パディングとマージンを取り除きます。
ベクトランの答えに追加する:ブラウザ間の互換性のために、table要素にcellspacing
属性も設定する必要があります。
<table cellspacing="0">
EDIT(完全を期すために、この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>
これは私のために働いた:
#table {
border-collapse: collapse;
border-spacing: 0;
}
Tdの画像の場合は、これを画像に使用します。
display: block;
それは私のために不要なスペースを削除します
標準に準拠したHTML 5では、このCSSをすべて追加して、テーブル内の画像間のスペースをすべて削除します。
table {
border-spacing: 0;
border-collapse: collapse;
}
td {
padding:0px;
}
td img {
display:block;
}
table
{
border-collapse: collapse;
}
テーブルの列を区切っているすべての枠線を折りたたみます...
または試してみる
<table cellspacing="0" style="border-spacing: 0;">
すべて同じcell-spacingを0にし、ボーダーの間隔を0にする.
楽しむ!
img
のtd
について、Jacobの回答に加えて、
body {line-height: 0;}
img {display: block; vertical-align: bottom;}
これはGmailを含むほとんどの電子メールクライアントに有効です。しかし、見通しは違います。 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>
cellpaddingとcellspacingを0に設定すると、行と列の間の不要なスペースが削除されます。
これを試して、
table{
border-collapse: collapse; /* 'cellspacing' equivalent */
}
table td,
table th{
padding: 0; /* 'cellpadding' equivalent */
}
この行をファイルの先頭に追加するとうまくいきました。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
適切なボーダープロパティを設定するためにCSSを変更すると、私は上記の行を追加するまで動作しませんでした
あなたはcolspanを持っているTRを取り除いて、それが何かを変えるかどうか確かめましたか?
正確なテーブルデザインになると、私はcolspansとrowspansがかなり厄介であることを経験しました。あなたのイメージがcolspan-TRなしで大丈夫に見えるなら、私はそこから始めて、入れ子になったテーブルセットを構築するでしょう。
また、あなたのstyle.cssは完成していないようですが、そこに何か問題があるのでしょうか。少なくともpadding: 0; margin: 0;
をテーブル(またはクラス "mytable")に追加します。あなたの画像もスペースやボーダーを持っていないことを確認してください(例えばimg { border: 0; }
をあなたのスタイルシートに追加することによって)。