zoukankan      html  css  js  c++  java
  • CSS多列布局

    前面的话

       CSS新增了多列布局特性,可以让浏览器确定何时结束一列和开始下一列,无需任何额外的标记。简单来说,就是CSS3多列布局可以自动将内容按指定的列数排列,这种特性实现的布局效果和报纸、杂志类排版非常相似。本文将详细介绍CSS多列布局的基本属性和用法

    列宽

      column-width主要用于给元素指定最优的列宽度,实际列宽可能会更宽或更窄。如果不设置高度,文字将自动撑满整列,且最后一列的标点会溢出到容器外

      [注意]IE10+和chrome浏览器支持标准写法,而firefox、safari浏览器及移动端android、IOS需要添加前缀

    column-width

      值: auto | <length>

      初始值: auto

      应用于: block、inline-block、table-cell(firefox不支持为table-cell设置该属性)

      继承性: 无

      [注意]column-width不可为0和负值;当column-width的值为auto或column-width的值大于元素宽度width一半时,没有分列效果(更准确地,由其他属性来决定)

    列数

      column-count主要用于给元素指定允许的最大列数

      [注意]IE10+和chrome浏览器支持标准写法,而firefox、safari浏览器及移动端android、IOS需要添加前缀

    column-count

      值: auto | <length>

      初始值: auto

      应用于: block、inline-block、table-cell(firefox不支持为table-cell设置该属性)

      继承性: 无

      [注意]column-count不可为0和负值;当column-count的值为auto时,默认没有分列效果(更准确地,由其他属性来决定)

    列间距

      列间距column-gap用于定义相邻两列之间的空白间距

      [注意]IE10+和chrome浏览器支持标准写法,而firefox、safari浏览器及移动端android、IOS需要添加前缀

    column-gap

      值: normal | <length>

      初始值: normal

      应用于: block、inline-block、table-cell

      继承性: 无

      [注意]column-gap的normal值默认情况下相当于1em。column-gap值不可为负值

    列rule

      该属性用于绘制位于列间距水平中心的线条。该样式由column-rule-width、column-rule-style、column-rule-color这三条样式组成

      [注意]IE10+和chrome浏览器支持标准写法,而firefox、safari浏览器及移动端android、IOS需要添加前缀

    column-rule

      值: <column-rule-width> || <column-rule-style> || <column-rule-color>

      标准中说column-rule类似于border,但实际更类似于outline,因为该样式并不占据实际的物理尺寸。outline详细情况移步至此

      [注意]如果column-rule-width的宽度大于column-gap的宽度,则可能会显示在列框内容中

    跨列

      column-span属性用来定义子元素是否跨列

      [注意]firefox不支持该属性,IE10+和chrome浏览器支持标准写法,而safari浏览器及移动端android、IOS需要添加前缀

    column-span

      值: none | all

      初始值: none

      应用于: block元素、table-cell元素(只有safari支持为table-cell设置该属性)

      继承性: 无

    none: 默认不跨列
    all: 跨越所有列

      [注意]当跨列元素被绝对定位(包括固定定位)或浮动后,跨列将不生效

      [注意]当跨列元素与column-rule的修饰线重叠时,在IE和safari中,跨列元素将覆盖修饰线,而chrome浏览器存在bug,跨列元素的文本覆盖修饰线,但跨列元素的背景可能会消失。

    列填充

      在列布局中,有时由于内容不足,多列中的最后列往往没有足够内容填充,这时要实现所有列都具有相同高度的效果,需要使用列填充属性column-fill

    column-fill

      值: auto | balance

      初始值: auto

      应用于: block、inline-block

      继承性: 无

    auto: 默认各列高度随内容变化而变化
    balance: 各列高度根据内容最多的一列进行统一

      [注意]目前只有firefox支持带前缀的column-fill属性

    多列

      一般地,我们只关心是否分列以及列宽多少,对列间距并不考虑。于是,column这个column-width和column-count的复合属性就得到了比较广泛的使用

    columns: column-width || column-count

      [注意]由于column-width和column-count这两个值的单位不同,所以顺序无关

      要知道,多列布局主要由列宽、列间距、列数及元素宽度影响,其布局等式是

         元素宽度 = 列数 * 列宽 + (列数-1)*列间距 <=> 列数*(列宽+列间距) - 列间距 = 元素宽度
         或者, 列数 = (元素宽度+列间距)/(列宽+列间距)
         或者, 列宽 = (元素宽度+列间距)/列数 - 列间距

      此等式中,列间距为定值,其他三个值为可变值,以下是各个值推算情况,其中N为实际列数,W为实际列宽

    【1】如果元素宽度为auto,且列宽和列数都不是auto

      则 N = column-count W = column-width;

    【2】如果列宽为auto,但列数不是auto,元素宽度不为auto

      则 N = column-count W = max(0,(元素宽度 - ((N-1)*列间距))/N)

    【3】如果列宽不为auto,但列数是auto,元素宽度不为auto

      则 N = max(1,floor((元素宽度 + 列间距) / (列宽 + 列间距 )) W = ((元素宽度 + 列间距) / N) - 列间距

    【4】如果列宽和列数都不是auto,元素宽度不为auto

      则 N = min(列宽 , floor((元素宽度 + 列间距) / (列宽 + 列间距))) W = ((元素宽度 + 列间距) / N) - 列间距

      [注意]若列数为小数,只保留整数部分

      [注意]所有的情况都是先推算出实际列数,再由实际列数推算实际列宽

  • 相关阅读:
    DevExpress WPF入门指南:加载动画的应用
    DevExpress v17.2—WPF篇(一)
    添加MyEclipse WebSphere Portal Server支持(二)
    DevExpress v17.2—WinForms篇(六)
    MyEclipse 2017 CI 9 发布(附下载)
    DevExpress v17.2新版亮点—WinForms篇(五)
    DevExpress v17.2新版亮点—WinForms篇(四)
    添加MyEclipse WebSphere Portal Server支持(一)
    内嵌iframe页面在IOS下会受内部元素影响自动撑开的问题
    组合 a 标签与 canvas 实现图片资源的安全下载的方法与技巧
  • 原文地址:https://www.cnblogs.com/xiaohuochai/p/5344541.html
Copyright © 2011-2022 走看看