2012-10-11 63 views
0

我需要一些帮助,使此布局仅适用于divcss将表格布局转换为CSS布局

<table> 
    <tr> 
     <td colspan="2">Header</td> 
    </tr> 
    <tr> 
     <td>Side Bar</td> 
     <td> 
      <table> 
       <tr> 
        <td>Top Menu</td> 
       </tr> 
       <tr> 
        <td>Main Content</td> 
       </tr> 
      </table> 
     </td> 
    </tr> 
    <tr> 
     <td colspan="2">Footer</td> 
    </tr> 
</table> 

我想是这样的:

<div id="page"> 
    <div id="main-header"></div> 
    <div> 
     <div id="side-bar"></div> 
     <div> 
      <div id="top-nav"></div> 
      <div id="main-content"></div> 
     </div> 
    </div> 
    <div id="main-footer"></div> 
</div> 

但我对CSS有点卡住了。

+0

我试过一些float = left divs,但后来主要内容浮起来了,如果我清除它会在整个布局下面。 – Sam

+0

您需要发布您的html&css并从那里采取。 – Jawad

回答

2

这是我想出了:

<!DOCTYPE HTML> 
<html lang="en-US"> 
<head> 
    <meta charset="UTF-8"> 
    <title></title> 
    <style type="text/css"> 
     * { 
      margin: 0; 
      padding: 0; 
      box-sizing: border-box; 
     } 
     body { 
      font-size: 16px; 
     } 
     #wrapper { 
      width: 80%; 
      min-width: 500px; 
      margin: 10px auto; 
      background: rgb(200,200,200); 
     } 
     #wrapper header h1 { 
      text-align: center; 
      background: #BADA55; 
     } 
     #wrapper nav ul { 
      list-style: none; 
      font-size: 0; 
      text-align: center; 
      background: red; 
     } 
     #wrapper nav ul li { 
      display: inline-block; 
      font-size: 16px; 
      padding: 1em 2em; 
     } 
     #wrapper aside { 
      float: left; 
      width: 30%; 
      background: blue; 
     } 
     #main_content { 
      float: right; 
      width: 70%; 
      background: green; 
     } 
     #wrapper footer { 
      clear: both; 
      background: black; 
      color: white; 
     } 
    </style> 
</head> 
<body> 

<section id="wrapper"> 
    <header> 
     <h1>Main Header</h1> 
     <nav> 
      <ul> 
       <li>Link</li> 
       <li>Link</li> 
       <li>Link</li> 
       <li>Link</li> 
       <li>Link</li> 
      </ul> 
     </nav> 
    </header> 
    <section id="main_content"> 
     <p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus</p> 
    </section> 
    <aside> 
     <h3>Sidebar</h3> 
     <p>Sidebar content</p> 
    </aside> 
    <footer> 
     <p><small>Footer Information</small></p> 
    </footer> 
</section> 

</body> 
</html> 

它分为色彩,从而使每一个元素是很容易识别。

如果您对CSS/HTML有任何疑问,可以在评论中提问,我会回答。

div是一个通用的,完全非语义的包装元素。如果没有其他元素适合工作,则只使用<div>。如你所见,这里没有。所有元素都是语义和适当的。

+2

我认为CSS是OP正在寻找的东西。 – j08691

+0

“一点卡住CSS”你也需要发布你的CSS。意思是OP – Jawad

+0

我还没有css,没什么好用的 – Sam