html 瀑布流样式,HTML+CSS07 瀑布流布局

预备知识:Column布局

CSS Columns(多列布局)是一种定义了多栏布局的模块,它能够表现出将内容在列之间怎么流动的以及间隙和分割线怎么使用。浏览器的兼容性还是不错的,生产环境建议-moz和-webkit前缀以及不加前缀三种形式共同使用

8e2db1368ab95ee99ae48fa59461c880.png

columns

CSS多列布局可以轻松的实现多列的瀑布流布局,它的两个关键属性是column-count和cloumn-width

column-count设置多列布局得的列数,取值:

auto,由其他CSS属性来决定列的数量,比如column-width

,用来描述元素内容被划分的列数,如果column-width也设置为非零值,此参数仅表示所允许的最大列数

column-width用来设定最佳列宽,取值:

auto,由其他CSS属性来决定列的数量,比如column-count

,用来描述最理想的列宽,实际列宽可能更宽(用来填充可用空间)也可能更窄(当可用空间比指明的列宽更窄),如果column-width也设置为非零值,此参数仅表示所允许的最大列数

因为这两个属性值没有重叠,可以使用columns来进行简写:

column-count: 5 → columns: 5

column-width: 200px → columns: 200px

columns: 5 200px

复制代码

高度

一般来说,多列布局的高度是由浏览器自动确定的,但是也可以通过设置height或者max-height来限制列的高度。这样在生成新的一列之前都会仅允许增加到这个高度,剩下的内容会放置到下一列中。(这样会令我们的设置的column-count失效)

未设置高度:

8e2db1368ab95ee99ae48fa59461c880.png

设置最大高度后,列数超出了设置的column-count: 4:

b43809fedbe7675708412522d3533f43.png

列间隙

column-gap属性来设置列之间的间隔,取值:

normal,多列布局时默认值为1em,其他类型布局时默认值为0

,非负整数

,基于父元素宽度的百分比

列分割线

可以通过column-rule属性来为多列布局时各列之间添加分割线,它与border属性类似,也是一个缩写属性,它是由下面三个属性构成:

column-rule-width,指定分割线宽度,可以设定具体数值,也可以在thin、medium、thick之间取值

column-rule-style,指定分割线的样式,取值与border-style类似

column-rule-color,指定分割线的颜色

添加这个属性后column-rule: thick inset blue:

472b4d1e6f48687478237f8d6611ef72.png

使用多列布局实现瀑布流

使用多列布局实现瀑布流就十分简单了:

DOM结构直接用一个多列布局的容器,内部防止排列的元素即可:

复制代码

关键是设置container的多列布局的相关属性:

.container {

width: 1000px;

column-count: 4;

column-gap: 1em;

column-width: 220px;

}

.img-container {

margin-bottom: 10px;;

break-inside: avoid;

}

复制代码

此外,需要在内部元素上添加一个break-inside属性,用来防止多列布局中内容以外中断,取值:

auto,不强制也不禁止元素内的页、列中断

avoid,避免元素内的分页符、列中断以及区域中断

aviod-page,避免元素内的分页符

aviod-column,避免元素内的列中断

aviod-region,避免元素内的区域中断

实现的效果:

4a82d69c288057851dd76ea455b1d56c.png

多列布局来实现瀑布流布局的优点是灵活简单,并且不需要JavaScript参与,且DOM结构很简单,缺点除了需要考虑兼容性之外,我没发现缺点

使用Flex布局实现瀑布流

之前面试的时候被问到,如何实现瀑布流,我当时并不知道多列布局,自然而然就想到使用Flex实现。Flex完全可以实现,但是DOM结构会稍微复杂一些

首先需要让父容器成为Flex容器,再使用4个

充当列,然后向每个列中分别添加元素即可(网上有一些方案认为列元素内部还需要使用Flex布局,然后flex-direction为column,我觉得没有必要,自然向下排列就可以了吧)

复制代码

CSS设置并不复杂:

.container {

display: flex;

width: 1000px;

justify-content: space-around;

}

复制代码

实现的效果:

b28d6b3ceb8bd86cd45baf7f782b01c9.png

这种方法优点是兼容性好,缺点主要是DOM结构复杂一些,而且需要手动的将获取的元素插入到不同的列中,还需要综合考虑各列的高度,放着某一列高度超出其他列太多。

参考

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值