资讯专栏INFORMATION COLUMN

css揭秘笔记——结构与布局

张宪坤 / 2377人阅读

摘要:回退方案根据兄弟元素的数量来设置样式知识点伪类选择器只有一个列表项等效于一个正好有四个列表项的列表中的第一个列表项它之后的所有兄弟元素因此,有且只有四个列表项的情况就可以表示为如果列表项不是四个,则没有被选中。

自适应内部元素

我们希望 width 可以像 height 一样, 可以自动适应内容的宽度。假如有如下结构:

Lorem ipsum dolor ...

Lorem ipsum dolor sit amet, consectetur adipisicing elit.

Lorem ipsum dolor sit...

我们希望 figure 元素跟它所包含的图片一样宽(图片尺寸不固定),而且水平居中。而我们能想到的解决方案,如让 figure 元素浮动,或者使 figure 的父元素 text-aligin:center、再对所有子元素都设置 text-align:left。这些方法都不是特别理想。

css3中为 width 和 height 又增加了一些新的关键字,如min-content,它能使容器的宽度为内部最大的不可断行元素的宽度。

figure{
    max-width: 300px; /*回退方案*/
    max-width: min-content; 
    margin: auto;
}
figure>img{
    max-width: inherit;
}

根据兄弟元素的数量来设置样式

知识点:伪类选择器

只有一个列表项::only-child 等效于 :first-child:last-child
一个正好有四个列表项的列表中的第一个列表项: :first-child:nth-last-child(4)

ul>li{
    display: inline-block;
    padding: .5em 1em;
    border-radius: .5em;
    background: pink;
    color: white;
}
li:first-child:nth-last-child(4){
    background: deeppink;
}

它之后的所有兄弟元素: :first-child:nth-last-child(4)~li

li:first-child:nth-last-child(4) ~ li{
    background: deeppink;
}

因此,有且只有四个列表项的情况就可以表示为:

li:first-child:nth-last-child(4),
li:first-child:nth-last-child(4) ~ li{
    background: deeppink;
}

如果列表项不是四个,则没有被选中。

根据兄弟元素的数量范围来匹配元素

:nth-child()中的参数不仅可以是具体数字,也可以是an+b这样的表达式,其中 n 的范围是0到正无穷。
例如:n+4表示选中从第 4 个开始的所有子元素。(注意: 写成 4+n是不对的)

选中总数是4或是更多时选中所有列表项:

li:first-child:nth-last-child(n+4),
li:first-child:nth-last-child(n+4) ~ li{
    background: deeppink;
}  

参数是-n+4可以选中开头的4个元素

li:nth-child(-n+4){
    background: deeppink;
}

仅当列表中有4个或更少的列表项时,选中所有的列表项:

li:first-child:nth-last-child(-n+4),
li:first-child:nth-last-child(-n+4) ~ li{
    background: deeppink;
}

两种技巧混合,可以表示当列表项有2~6个时,选中所有列表项。

li:first-child:nth-last-child(n+2):nth-last-child(-n+6),
li:first-child:nth-last-child(n+2):nth-last-child(-n+6) ~ li{
    background: deeppink;
}

满幅的背景,定宽的内容

要实现一个背景占据整个视口,而内容固定宽度,居中布局。如:

一般的解决方案是为每个区块准备两层元素,分别为其设置样式:

Lorem ipsum dolor ...
footer{ background: #333; color: white; border: 1px solid #333;/*这一行是为了不让父元素和子元素的margin重叠(父元素margin为0,子元素为1em,重叠以长的为准,即为1em,背景默认background-clip为border-box,margin下面就会没有背景颜色。)*/ } .wrapper{ max-width: 900px; margin: 1em auto; }

CSS3中增加了一个calc()函数,上面代码中的 margin 的 auto 可以替换为 calc(50%-450px),这是一个长度值,因此可以作为父元素的 padding 值,代码可以改为:

 footer{
        background: #333;
        color: white;
        /*border: 1px solid #333;*//*没有margin重叠问题,也就不需要这一行*/
        padding: 1em calc(50% - 450px);
    }
    .wrapper{
        /*max-width: 900px;*/
        /*margin: 1em auto;*/
    }

因此,最终我们不再需要一个额外的元素:

footer{
    background: #333;
    color: white;
    padding: 1em; /*回退方案*/
    padding: 1em calc(50% - 450px); /*注意:calc中减号两边须有空格*/
}
垂直居中

水平居中很简单:

/*针对行内元素*/
text-align: center; 
/*针对块级元素*/
margin: auto;

如下结构:

Am I centered yet?

Center me, please!

基于绝对定位的解决方案

这个方案的前提是元素必须有固定的宽度和高度:

main{

    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -5em;
    margin-left: -10em;
    width: 20em;
    height: 10em;
} 

如果一般的块级元素,且父元素不是 , 还需要对父元素进行相对定位。

借助calc()函数,就可以省掉两行

main{
    position: absolute;
    top: calc(50% - 5em);
    left: calc(50% - 10em);
    width: 20em;
    height: 10em;
}

由于translate()函数中的百分比值是相对于自身的宽高计算的,所以可以解决固定宽高的问题:

main{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
基于视口单位的解决方案

如果使用 margin 的百分比值和 auto 关键字设置垂直水平居中,得到的效果可能并不是我们想要的:

main{
    width: 20em;
    margin: 50% auto 0;
    transform: translateY(-50%);
}


那是因为 margin 的百分比值是以父元素的宽作为基准的,即使对 margin-top 和 margin-bottom 也是这样。
如果只是想针对视口居中,可以使用视口单位解决。
1vw 表示视口宽度的 1%
1vh 表示视口高度的 1%
1vmin 表示视口宽高较小的那个(1vw 或 1vh)
1vmax 表示视口宽高较大的那个(1vw 或 1vh)

main{
    width: 20em;
    margin: 50vh auto 0;
    transform: translateY(-50%);
}
基于Flexbox 的解决方案
body{
    display: flex;
}

main{
    margin: auto;
}

当我们使用 Flexbox 时,margin:auto 不仅在水平方向上将元素居中,垂直方向上也是如此。
也可以这么写:

body{
    display: flex;
    justify-content: center;
    align-items: center;
}

使用这种方法,还可以将匿名容器垂直居中,如没有被标签包裹的文本节点:

Center me, please! mian{ display: flex; justify-content: center; align-items: center; width: 20em; height: 15em; }

紧贴底部的页脚

我们会遇到这样的问题,当页面内容不够长时,会出现页脚不能紧贴在最底部,而是紧跟在内容的下方。如下图:

固定高度的解决方案

如果页脚和页头的高度固定,首先我们计算出页脚和页头的高度,分别是7em和2.5em。

mian{
    min-height: calc(100vh - 7em - 2.5em);
    box-sizing: border-box; /*避免内边距或边框搞乱高度的计算*/
}

就OK了。
或者用一个额外的元素包裹住

元素:

#wrapper {
    min-height: calc(100vh - 7em);
} 

Flexbox解决方案

将 body 设置为flex,main 设置为可伸长。

body{
    display: flex;
    flex-flow: column;
    min-height: 100vh;
}
main{
    flex: 1;
}

搞定~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/112742.html

相关文章

  • css编码技巧【css揭秘读书笔记

    摘要:最近在看揭秘,于是写了文章来作笔记,除此以外还会补充一些自己遇到的笔试题。举例说明以上的代码有什么问题呢如果需要改变字号,那么同时需要调整行高。那么经过修改后的代码如下关于使用还是还是百分比,需要根据具体情况来决定。 最近在看《css揭秘》,于是写了文章来作笔记,除此以外还会补充一些自己遇到的笔试题。希望大家都有所收获。 css编码技巧 尽量减少代码重复 在实践中,代码可维护性的最大要...

    Miyang 评论0 收藏0
  • CSS技巧

    摘要:技巧使你的更加专业这是上关于技巧的一篇译文,另外你也可以在本项目看到原文。列举了一些很实用的技巧,比如给空内容的标签添加内容,逗号分隔列表等等。排序算法看源码,把它背下来吧排序算法的封装。主要帮助初学者更好的掌握排序算法的实现。 成为专业程序员路上用到的各种优秀资料、神器及框架 成为一名专业程序员的道路上,需要坚持练习、学习与积累,技术方面既要有一定的广度,更要有自己的深度。 Java...

    DangoSky 评论0 收藏0
  • CSS技巧

    摘要:技巧使你的更加专业这是上关于技巧的一篇译文,另外你也可以在本项目看到原文。列举了一些很实用的技巧,比如给空内容的标签添加内容,逗号分隔列表等等。排序算法看源码,把它背下来吧排序算法的封装。主要帮助初学者更好的掌握排序算法的实现。 成为专业程序员路上用到的各种优秀资料、神器及框架 成为一名专业程序员的道路上,需要坚持练习、学习与积累,技术方面既要有一定的广度,更要有自己的深度。 Java...

    zgbgx 评论0 收藏0
  • CSS技巧 - 收藏集 - 掘金

    摘要:笔者作为一位,将工作以来用到的各种优秀资料神器及框架整理在此,毕竟好记性不如烂键盘,此前端知识点大百科全书前端掘金,,不定期更新技巧前端掘金技巧,偶尔更新。计算数组的极值技巧使你的更加专业前端掘金一个帮你提升技巧的收藏集。 CSS 样式画各种图形 - 前端 - 掘金下面是一些我在 CSS 中经常用到的图案,还有一些是在css-tricks看到的。记录一下,以后会用到。会持续更新… 一、...

    Jonathan Shieber 评论0 收藏0
  • CSS技巧 - 收藏集 - 掘金

    摘要:笔者作为一位,将工作以来用到的各种优秀资料神器及框架整理在此,毕竟好记性不如烂键盘,此前端知识点大百科全书前端掘金,,不定期更新技巧前端掘金技巧,偶尔更新。计算数组的极值技巧使你的更加专业前端掘金一个帮你提升技巧的收藏集。 CSS 样式画各种图形 - 前端 - 掘金下面是一些我在 CSS 中经常用到的图案,还有一些是在css-tricks看到的。记录一下,以后会用到。会持续更新… 一、...

    SHERlocked93 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<