by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8436

本文可全文转载,个人网站无需授权,只要保留原作者、出处以及文中链接即可,任何网站均可摘要聚合,商用请联系授权。

一、前言&索引

Multiple-column布局,也称多列布局、多栏布局,我自己喜欢叫做分栏布局,这种布局可以讲内容布局到一组列框,类似于报纸上的排版。

分栏布局非常特殊,有别于传统布局方法,它将包括包括所有子元素在内的所有内容拆分为列,这与我们打印网页时候时页面内容分割成不同的页面的方式类似。

分栏布局IE10+都可以使用,API稳定,移动端兼容性比flex布局要好,虽然设计初衷不一样,但很多布局都可以实现。甚至某些场景下,只能使用分栏布局才能实现。很有学习的必要。

与分栏布局相关的CSS属性包括:

二、直接相关CSS属性

1. column-width

column-width表示每一栏/列的最佳宽度。

如果我们只设定column-width,浏览器会自动根据现有容器宽度划分栏目的个数。

语法如下:

column-width: | auto;

其中:

表示设定的最佳列宽值。实际呈现的每一栏的宽度可能与指定值不同,具体内容参见下面的细节描述。

auto

默认值。表示每一栏的宽度由其它CSS属性决定,例如

一些细节:

column-width有时候会无效。例如容器宽度400像素,设定的每一栏宽度是300像素,不足以分栏,此时内容填充填充表现为充分利用可用空间,最终呈现的列宽比设定的更宽。又例如容器宽度400像素,column-width设置为500像素,则最终分栏宽度不会超过容器宽度,比设定的500像素要小。

column-width不支持负值,也不支持百分比值。

实地演示:

点击下面的选项卡,感受下不同column-width属性值下的布局表现:

column-width:autocolumn-width:8%(无效)column-width:80pxcolumn-width:8em

CSS column-width属性指定多列布局中的理想列宽。容器将具有尽可能多的列,其中任何一列的宽度都不小于列宽值。如果容器的宽度小于指定值,则单列的宽度将小于声明的列宽。

此属性可以帮助您创建适合不同屏幕大小的响应式设计。尤其是在column-count属性(具有优先权)存在的情况下,必须指定所有相关的长度值以获得精确的列宽度。在水平文本中,这些长度值包括width、column-width、column-gap,以及column-rule-width。

2. column-count

column-count表示理想的分栏数目。

语法如下:

column-count: | auto;

其中:

表示分栏数目,整数值。

auto

默认值。表示分栏数目由其它CSS属性决定,例如

一些细节:

column-count与column-width都有可能有更高的优先级,要看具体场景。优先级计算诀窍就是统一转换column-count值,哪个小就使用哪一个。

column-count不支持负值,也不支持0。

实地演示:

点击下面的选项卡,感受下不同column-count属性值下的布局表现:

column-count:autocolumn-count:2column-count:2;

column-width:200pxcolumn-count:4;

column-width:200px

这个选项卡测试切换效果建议在PC端浏览器上体验,在移动端,由于宽度限制感受不到后两个选项的差异。

在PC桌面端,容器宽度大约700像素出头一点,此时column-width:200px换算成column-count大约3.6的样子。于是,选项卡3分成了2栏,因为column-count:2值更小;而选项卡4由于column-width换算值更小,因此column-width优先级更高,最终分成了3栏显示。

其中,我们重点关注选项卡3和选项卡4。在PC算,由于容器宽度大约700像素出头一点,因此column-width:200px可以近似看成column-count为3.6的样子。还记不记得上面提到的优先级计算诀窍:哪个值小哪个优先级高。于是,选项卡3分成了2栏,因为column-count:2值更小;而选项卡4由于column-width换算值更小,因此column-width优先级更高,最终分成了3栏显示。

另外,从两栏效果可以看出,columns每一个栏目的高度并不总是相等的,内容的分割也不总是均匀的,浏览器有一套自己的算法。

3. columns

columns是column-width和column-count属性的缩写。举几个使用的例子:

/* 栏目宽度 */

columns: 18em;

/* 栏目数目 */

columns: auto;

columns: 2;

/* 同时定义宽度和数目 */

columns: 2 auto;

columns: auto 12em;

columns: auto auto;

不展开。

4. column-rule-color

column-rule-color表示每个栏目中间分隔线的颜色。

语法如下:

column-rule-color:

支持的属性值和border-color是一模一样的,例如:

column-rule-color: red;

column-rule-color: rgb(255, 0, 0);

column-rule-color: transparent;

column-rule-color: hsla(0, 100%, 50%, 0.5);

默认值是当前color属性的计算值。

实例如下:

column-rule-style: dotted;

column-rule-color: red;

实时效果如下:

由于column-rule默认的分隔线的类型是none,因此,我们必须要指定column-rule-style,否则会看不到分隔线。column-rule-*相关属性值和border-*是一样的。

5. column-rule-style

column-rule-style表示每个栏目中间分隔线的类型。支持的属性值和border-style是一模一样的,例如:

column-rule-style: none;

column-rule-style: hidden;

column-rule-style: dotted;

column-rule-style: dashed;

column-rule-style: solid;

column-rule-style: double;

column-rule-style: groove;

column-rule-style: ridge;

column-rule-style: inset;

column-rule-style: outset;

每个属性值具体效果可以点击下面选项卡进行体验:

nonehiddendotteddashedsoliddoublegrooveridgeinsetoutset

其中dotted表示虚点,dashed表示虚线,solid表示实线。这三个比较常用,就不多展开。然后着重提下后面几个,首先是double,double表示

双线边框,顾名思意,两根线,且为实线。虽然平常我们使用少,但是兼容性非常好。视觉表现为线框-透明-线框。其它column-rule-style类型,如inset(内凹),outset(外凸),groove(沟槽),ridge(山脊),风格老土过时,且兼容性惨不忍睹,因此,没有任何实用价值,大家无需关心。

科学研究表明,对于大多数人而言,无论在这里写的是什么文字,都不会被读者注意到。

5. column-rule-width

column-rule-width表示每个栏目中间分隔线的宽度大小。支持的属性值和border-width是一模一样的,例如:

/* 关键字值 */

column-rule-width: thin;

column-rule-width: medium; /* 默认值 */

column-rule-width: thick;

/* 具体长度值 */

column-rule-width: 1px;

column-rule-width: 2.5em;

我们平常使用column-rule-width几乎全是固定的数值,比方说column-rule-width:1px之类,于是对关键字属性值不太了解,这里介绍下。column-rule-width支持三个关键字属性值,分别是thin,medium(默认值)和thick,对应的具体尺寸大小如下:

thin:薄薄的,等同于1px;

medium(默认值):薄厚均匀,等同于3px;

thick:厚厚的,等同于5px;

不知大家有没有想过这么一个问题:为什么默认宽度大小是medium,也就是3px,明明thin(1px)宽度更常用吧?这是因为……column-rule-style:double至少3px才有效果!

6. column-rule

column-rule是border是border-style,border-width和border-color的缩写一样。

其他没什么好说的,几个属性值顺序不讲究,随便。除了

7. column-span

column-span有点类似于表格布局中的colspan这个HTML属性,表示某一个内容是否跨多栏显示。

语法

column-span: none;

column-span: all;

其中:

none

表示不横跨多栏,默认值。

all

表示横跨所有垂直列。

我们一起来看一个例子,就知道这个属性是干嘛用的了:

column-span:nonecolumn-span:all

在HTML中,类似单元格

元素可以设置colspan属性,表示合并单元格,例如colspan="3"表示3个普通单元格合并成1个大的单元格。

column-span这个CSS属性作用与之类似,只是不能指定具体的数目。要么不跨列,要跨就跨全部条列。

在我们想要在垂直分栏显示的文章中插一个横贯整个页面的广告的时候,就可以使用这个属性。或者单纯只是希望上下再垂直分栏显示,也可以使用该属性。

实际开发的时候,非指定某个元素column-span:all,没有文本内容,就一个高度,或者加个水平边框,就可以将文章内容进一步上下分栏。于是,一篇文章的内容,就如报纸排版一样,想要在哪里分栏就随心所欲了。

当然,插入通栏广告也可以使用该属性。

8. column-fill

column-fill作用是当内容分栏的时候,如何平衡每一栏填充的内容。

语法

column-fill: auto;

column-fill: balance;

column-fill: balance-all;

其中:

auto

按顺序填充每一列。内容只占用它需要的空间。

balance

默认值。尽可能在列之间平衡内容。在分隔断开的上下文中,只有最后一个片段是平衡的。举例来说就是有多个

元素,正好最后一个

换行了,那这个

元素的内容前后等分,保持平衡。这就会造成最后一栏内容较少的情况。

balance-all(可忽略)

尽可能在列之间平衡内容。在分隔断开的上下文中,所有片段都是平衡的。

我们一起来看一个与column-fill属性相关的demo(目前仅Firefox浏览器有正确表现):

column-fill:autocolumn-fill:balancecolumn-fill:balance-all

这是一堆分成多个的文本列。CSS`column-fill`属性是用于将内容均匀地分布在一起所有列。

column-fill这个属性的准确渲染需要在Firefox浏览器下才可以看到。当我们点击auto的时候,所有的文字内容应该挤在最左边一栏中才是正确的。但是Chrome和IE下却和balance属性值表现一样。

上面demo当我们点击'auto'这个选项卡的时候,正确的表现应该如下图所示:

若要让所有浏览器下column-fill:auto都有效果,需要给容器元素设置固定的高度值菜系。

还有,根据我在IE,Chrome和Firefox浏览器下测试,这几个浏览器点击balance-all都没能识别。我查看官方草案文档,也没有balance-all的示意,该属性值大家可以忽略。

9. column-gap

column-gap表示每一栏之间的那个空白间隙大小。

语法

column-gap: normal | ;

具体

/* 关键字值 */

column-gap: normal;

/* 长度值 */

column-gap: 3px;

column-gap: 3em;

/* 百分比值 */

column-gap: 3%;

其中:

normal

默认值。在多栏布局中为1em,在其它类型的布局中为0。

具体的长度值。不支持负数。

百分比值。和column-width不同,column-gap支持百分比值。同样,不能是负数。

实地demo演示

column-gap:normalcolumn-gap:8%column-gap:80pxcolumn-gap:8em

虽然column-gap属性的默认值normal最终的表现就是1em,但并不表示可以和数值属性值产生transition过渡效果。因此,当我们点击到第一个选项卡的时候,宽度变化是突然的,而不是连续的。

column-gap和columns属性发生冲突的时候,例如,column-gap太大,导致空间不足,此时,column-gap是会被舍弃的。

三、间接相关CSS属性

每个可能的断点(换句话说,每个元素边界)受三个属性的影响:前一个元素的break-after值,下一个元素的

下面要介绍的3个属性,可以控制分栏布局中当前元素前后是否允许分栏。

1. break-after

break-after这个CSS属性定义页面,列或区域中断在生成的框之后应该如何表现。如果没有生成框,则忽略该属性。

break-after支持属性很多,但大多浏览器不支持,我们目前只要关注下面两个属性值就好了:

break-after: auto;

break-after: avoid;

其中:

auto

允许但不强制在主框之后插入任何中断(page,column或region布局下)。

avoid

避免在主体框后插入任何分隔符(page,column或region布局下)。

2. break-before

break-before这个CSS属性定义页面,列或区域中断在生成的框之前应该如何表现。如果没有生成框,则忽略该属性。

break-before支持属性很多,但大多浏览器不支持,我们目前只要关注下面两个属性值就好了:

break-before: auto;

break-before: avoid;

其中:

auto

允许但不强制在主框之前插入任何中断(page,column或region布局下)。

avoid

避免在主体框前插入任何分隔符(page,column或region布局下)。

3. break-inside

break-inside这个CSS属性定义页面、列或区域发生中断时候的元素该如何表现。如果没有中断,则忽略该属性。

break-inside支持属性相对少一些,同样的,我们目前只要关注下面两个属性值就好了:

break-inside: auto;

break-inside: avoid;

其中:

auto

元素可以中断。

avoid

元素不能中断。

demo实例页面

拿column分栏布局举例,分栏布局在流动和平衡内容方面做得很好。不幸的是,并非所有元素都能优雅地流动。有时元素会断开分布在两个列中。如下图所示:

有时候,我们希望我们的条目一个元素一个元素都是独立的,前后都不断开,此时,就可以使用break-inside:avoid实现:

.list {

-webkit-column-break-inside: avoid; /* Chrome, Safari, Opera */

page-break-inside: avoid; /* Firefox */

break-inside: avoid; /* IE 10+, Chrome, Safari, Opera */

}

此时效果如下截图:

其他

应该是上个月,还介绍了一个名为box-decoration-break的CSS属性,也与columns布局是相关的,其作用更多的是元素断开后的装饰表现。有兴趣可以参见这篇文章:“CSS/CSS3 box-decoration-break属性简介”。

四、一些特殊布局应用举例

CSS3 columns多栏布局可以实现水平翻书阅读效果。

CSS3 columns多栏布局还可以用来实现等分导航效果,支持单行和多行,类似flex布局那种效果,但兼容性比flex要好。本文篇幅已经很长了,相关内容我回头专门写一篇文章介绍。

其他类似主题文章

能够阅读到这里的都是真爱,感谢,比心!

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。

本文地址:https://www.zhangxinxu.com/wordpress/?p=8436

(本篇完)

column分栏布局只是文字布局吗_写给自己看的CSS columns分栏布局教程相关推荐

  1. mysql库垂按照模块_前任都能看懂的分库分表方案

    我们都知道,随着业务量的增长,数据量也会随之增加,这个时候就需要关注业务大表,因为大表会影响查询性能,DDL变更时间很长,影响业务的可用性,同时导致从库延迟很大,如果业务做了读写分离,导致用户重复操作 ...

  2. 计算机页面分隔符号点过之后出现点点,操作: 1、页面布局页签-分隔符-第二部分分节符(这里选了插入分节符并在下一页上开始新节)...

    本文分享7个鲜为人知但是超实用的Word 技巧,可以帮你大幅度提升工作效率,一起来收! 一.分页&分节概念 很多人包括程先生在写毕业论文之前,可能只是用过分页功能,却不晓得还有更为体贴入微的分 ...

  3. css网页布局中文字排版的属性和用法

    前段时间,学习了几个大的网站的图文混排的方法.今天总结下, css网页布局中文字排版的相关属性以及用法 .包括:设定字体.颜色.大小.段落空白,首字下沉.首行缩进.中文字的截断.固定宽度词内折行(wo ...

  4. CSS实现多栏布局的几种方式

    css实现多栏布局的几种方式 假如把下面的三个div显示在同一行 <div id="parent"><div id="box1">1&l ...

  5. Android Compose 新闻App(四)下拉刷新、复杂数据、网格布局、文字样式

    Compose 新闻App(四)下拉刷新.复杂数据.网格布局.文字样式 前言 正文 一.下拉刷新 ① 添加依赖 ② 使用 ③ 样式更改 二.刷新数据 三.复杂数据 四.复杂列表 ① 更改返回数据 ② ...

  6. css的经典三栏布局如何实现,css 实现三栏布局的四种方式

    三栏布局就是左中右,左右两边固定,中间自适应. 1. 绝对定位 左边 中间 右边 body { padding: ; margin: ; } /* 绝对定位 */ .left, .right { po ...

  7. Word中摘要和正文同时分栏后,正文跑到下一页,怎么办?或Word分栏后第一页明明有空位后面的文字却自动跳到第二页了,怎么办?...

    问题1:Word中摘要和正文同时分栏后,正文跑到下一页,怎么办?或Word分栏后第一页明明有空位后面的文字却自动跳到第二页了,怎么办? 答:在word2010中,菜单栏中最左侧选"文件&qu ...

  8. css实用技巧:巧用css实现两栏等高布局

    又到了利用碎片学习的时间了,看看这个小案例,超级实用的一个css技巧:css实现两栏等高布局. 样式方面: <style> #box{ width:900px; font-size:28p ...

  9. html怎么样做出两列布局页面,HTML+CSS实现两栏和三栏布局

    三栏布局 三列自适应布局通常指两边定宽,中间部分宽度自适应.这里主要分为两大类,一类是基于position传统的实现,一类是基于css3新特性弹性盒模型布局实现. 基于传统的position进行布局 ...

最新文章

  1. Python第三周 学习笔记(2)
  2. 【English】哈佛大学用这12张图,让你远离负能量
  3. 10分钟学会js处理json常用方法
  4. Linux下的tr编辑器命令详解
  5. 【图文详解】JDK1.8的安装与环境变量配置(win10)
  6. 容器与Pod到底有什么区别和联系?
  7. 放大电路频率响应基础概念
  8. 信息安全工程师笔记-入侵检测技术原理与应用
  9. Android学习——SharedPreferences
  10. 外贸网站服务器搬迁方案,WordPress网站迁移到新服务器教程
  11. 区块链:POA委员会选举机制
  12. php mysql后台管理模板_[开源]TP6后台管理模板
  13. 【《Real-Time Rendering 3rd》 提炼总结】(五) 第六章 · 纹理贴图及相关技术 The Texturing
  14. 淘宝、百度、腾讯、京东 那不得不说的四角恋故事
  15. 1009 - Back to Underworld(DFS)
  16. python中mysqldb模块_Python学习之MySQLdb模块
  17. 文件上传漏洞攻击与防御
  18. 热烈欢迎云南财经大学统计与数学学院院长石磊教授来芝诺数据视察指导工作
  19. 基于GAN的语音转换技术及语音合成TTS
  20. DevExpress_Winform_使用汇总

热门文章

  1. ThreadPoolExecutor的参数与线程池的五个状态
  2. Docker高级篇-Docker容器内Redis集群配置
  3. 《数据结构》C语言版 (清华严蔚敏版)详解
  4. GitHub Actions 实现 Azure Infra 资源的自动化部署
  5. inputstreamreader用法
  6. 一个研究生读完三年需要花多少钱?
  7. 投影仪玩法多,你知道如何使用
  8. 换硬盘之后如何迁移 hexo 博客
  9. 进阶篇之纯css 字体实现五角星(半颗星)评分
  10. 如何搭建直播app系统开发流程及难点的介绍