zoukankan      html  css  js  c++  java
  • 用CSS实现“表格布局”

      当我们进行浮动布局时,会发现存在着非浮动元素与浮动元素的底部难以对齐的情况,这就是浮动布局的缺陷。因此,过去的前端工作者曾利用<table>以实现“表格布局”。因为表格中同一行的单元格行高总是一致的,所以“表格布局”可以避免“浮动布局”时出现的“底部对不齐”情况,下面是经典的利用<table>实现“双栏布局”的框架:

    <table>
        <tr>
            <td>
                <!--左侧栏内容-->
            </td>
            
            <td>
                <!--右侧栏内容-->
            </td>
        </tr>
    </table>

      但是随着HTML5的到来,HTML标签越来越强调“语义化”,即合理使用HTML标记以及其特有的属性去格式化文档内容。因此,利用<table>来实现“表格布局”是不推荐的,因为此时<table>中的内容并不是一个真的“表格”,不符合“语义化”的追求。那么,在追求语义化的时代,该如何实现传统的“表格布局”呢?那就是借助CSS来实现。

      利用CSS来实现“表格布局”很简单,第一步是把传统<table>布局中的<table>、<tr>、<td>改为合适的、符合“语义化”的标签,比如说上面的“双栏布局”改成这样:

    <main>
        <section>
            <aside>
                <!--左侧栏内容-->
            </aside>
            
            <article>
                <!--右侧栏内容-->
            </article>
        </section>
    </main>

      然后为这些标签添加对应的display属性:

    <main style="display:table">
        <section style="display:table-row">
            <aside style="display:table-cell">
                <!--左侧栏内容-->
            </aside>
            
            <article style="display:table-cell">
                <!--右侧栏内容-->
            </article>
        </section>
    </main>

      其实将上述代码与传统<table>布局的代码一对比,可以看出,变化之处就是:

      替换掉<table>的<main>有了一个“display:table”样式

      替换掉<tr>的<section>有了一个“display:table-row”样式

      替换掉<td>的<aside>和<article>分别有了一个“display:table-cell”样式。

      用CSS来替代<table>进行“表格布局”的思路是基本一致的,只是进一步将页面的结构与表现分离开来,这样做最大的好处就是可以使HTML标签尽量做到“语义化”。

  • 相关阅读:
    setValue:forUndefinedKey:]: this class is not key value coding-compliant for the key
    Kinect 骨骼追踪数据的处理方法
    了解与建设有中国特色的Android M&N(Android6.0和7.0新特性分析)
    【计算机视觉】深度相机(一)--TOF总结
    A million requests per second with Python
    buf.fill()
    buf.slice()
    buf.toJSON()
    buf.toString()
    Buffer.compare()
  • 原文地址:https://www.cnblogs.com/shixizhi/p/8319298.html
Copyright © 2011-2022 走看看