html - 3 列布局 HTML/CSS

标签 html css

我有以下 HTML 布局:

<div class="container">
   <div class="column-center">Column center</div>
   <div class="column-left">Column left</div>
   <div class="column-right">Column right</div>
</div>

是否有机会仅使用 CSS 在不更改 HTML 的情况下像下面的示例网格那样排列列?

----------------------------------------------------
|              |                   |               |
| Column left  |   Column center   | Column right  |
|              |                   |               |
----------------------------------------------------

最佳答案

应该这样做:

.column-left{ float: left; width: 33.333%; }
.column-right{ float: right; width: 33.333%; }
.column-center{ display: inline-block; width: 33.333%; }

DEMO

编辑

要对更多的列执行此操作,您可以构建一个非常简单的网格系统。例如,像这样的东西应该适用于五列布局:

.column {
    float: left;
    position: relative;
    width: 20%;
  
    /*for demo purposes only */
    background: #f2f2f2;
    border: 1px solid #e6e6e6;
    box-sizing: border-box;
}

.column-offset-1 {
    left: 20%;
}
.column-offset-2 {
    left: 40%;
}
.column-offset-3 {
    left: 60%;
}
.column-offset-4 {
    left: 80%;
}

.column-inset-1 {
    left: -20%;
}
.column-inset-2 {
    left: -40%;
}
.column-inset-3 {
    left: -60%;
}
.column-inset-4 {
    left: -80%;
}
<div class="container">
   <div class="column column-one column-offset-2">Column one</div>
   <div class="column column-two column-inset-1">Column two</div>
   <div class="column column-three column-offset-1">Column three</div>
   <div class="column column-four column-inset-2">Column four</div>
   <div class="column column-five">Column five</div>
</div>

或者,如果您足够幸运能够只支持现代浏览器,您可以使用 flexible boxes :

.container {
    display: flex;
}

.column {
    flex: 1;
    
    /*for demo purposes only */
    background: #f2f2f2;
    border: 1px solid #e6e6e6;
    box-sizing: border-box;
}

.column-one {
    order: 3;
}
.column-two {
    order: 1;
}
.column-three {
    order: 4;
}
.column-four {
    order: 2;
}
.column-five {
    order: 5;
}
<div class="container">
   <div class="column column-one">Column one</div>
   <div class="column column-two">Column two</div>
   <div class="column column-three">Column three</div>
   <div class="column column-four">Column four</div>
   <div class="column column-five">Column five</div>
</div>

关于html - 3 列布局 HTML/CSS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20566660/

相关文章:

html - 为什么这个 CSS 动画是正向渲染而不是反向渲染?

javascript - 为什么 if 语句不起作用并使用显示 : none? 使我的元素消失

html - 您能否仅将 CSS 应用于包装的文本,即第二行和后续行?

html - 如何修复具有固定大小的行 GridView 产品?

html - CSS Flexbox 列溢出

html - 如何操作输入框的位置?

css - 悬停链接时导航栏边距出现问题

javascript - 调整屏幕大小时,表格会达到最大高度

html - 更多 CSS 对齐问题

html - div中的Struts2标签显示为空