tip:有问题或者需要大厂内推的+我脉脉哦:丛培森 ٩( ‘ω’ )و
CSS3中增加了可以实现多列布局的属性
在此之前的实现很麻烦可能需要各种定位
现在我们只需要一个属性就可以实现
多列布局类似于我们的报纸布局
这样可以方便读者观看
#多列数量与多列宽度#
如果一行文字太长的话,我们可能会没有读下去的欲望像这样
<div class="demo">......</div>
.demo {width: 600px;height: 200px;border: 1px solid black;
}
多列数量column-count可以指定你想要的列数
浏览器会自己设置合适的列宽度
.demo {width: 600px;height: 200px;border: 1px solid black;column-count: 3; /*增*/
}
不指定列数也可以使用column-width设置列宽度
和上面的代码是等价的
.demo {width: 600px;height: 200px;border: 1px solid black;column-width: 11em; /*改*/
}
如果你设置的宽度值不足于撑满整个元素
那么浏览器会尽量使用最大的宽度保证列数撑满整个元素
比如说上面的11em改为10em,浏览器同样会显示3列布局
#简写的多列语法#
column-count与column-width可以合成一个复合属性columns
可以通过这个属性设置列宽、列数、或者两者都有
不过一般使用的时候,设置其中一个属性就能满足我们的需求
.demo {width: 600px;height: 200px;border: 1px solid black;columns: 3;/*或者columns: 11em;*//*或者columns: 11em 3;*/
}
#列间隔宽度#
多列布局列与列之间存在这间隔
默认的间隔是1em
我们可以通过column-gap属性控制列间隔
.demo {width: 600px;height: 200px;border: 1px solid black;columns: 3;column-gap: 2em; /*增*/
}
注意如果你的列间隔设置的过大, 文本会溢出的
所以应该配合合适的列数来控制
#元素横跨列#
我在文本中加入一个标题元素并且改一下高度
<div class="demo"><h1>Angel Beats</h1>......</div>
.demo {width: 600px;height: 280px;/*改*/border: 1px solid black;columns: 3;
}
默认的情况下,h1元素只是占在第一列中
如果我想要让他置顶在多有列之上,怎么做呢?
对h1元素设置样式
h1 {column-span: all; <--text-align: center;
}
column-span可以指定元素横跨的列数默认属性值是1
设置为all,可以让元素横跨所有列
#列间隔样式#
如果你觉得列与列之间只是空格间隔过于枯燥
我们可以通过column-rule堆列间隔设置“规则”
这个属性是一个复合属性,子属性如下
- column-rule-width
- column-rule-style
- column-rule-color
有点类似于我们设置border属性
.demo {width: 600px;height: 200px;border: 1px solid black;columns: 3;column-rule: 1px solid black;
}
这样列与列之间就用了一个1像素宽的黑色实线
colum-rule-width除了可以设置像素外,
还有三个关键字thin、medium、thick设置三种宽度
column-rule-style属性值有如下关键字
- none 无
- hidden 隐藏
- dotted 点状
- dashed 虚线
- solid 实线
- double 双线
- groove 定义 3D grooved 规则
- ridge 定义 3D ridged 规则
- inset 定义 3D inset 规则
- outset定义 3D outset 规则
其中后四种的效果取决于宽度和颜色值,先了解一下
CSS3的多列布局用的比较少
但是最基本的属性我们还是要知道的
主页传送门