目录
0x00 min-content 宽度自适应
0x01 根据兄弟元素的数量来设置样式
:nth-child()
0x02 calc
0x03 垂直居中
基于绝对定位的解决方案
基于 FlexBox 的解决方案
0x04 紧贴底部的页脚
首页 web前端 css教程 CSS结构与布局

CSS结构与布局

Feb 18, 2017 pm 02:55 PM
css


0x00 min-content 宽度自适应

CSS3 新增宽度属性值 width:min-content 可以将容器的宽度值设置为容器内最大的不可断行的宽度(最宽的单词,图片,或者具有固定宽度的盒元素)

figure{
    width:min-content;
    margin: auto;    
}
登录后复制

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

我们知道伪元素选择器 :only-child,其实,它可以等效于:first-child:last-child,即是第一项的同时也是最后一项,所以从逻辑上来讲它是唯一的。而:last-child 也是:nth-last-child(1)的快捷写法。

那么接下来思考一个问题,li:first-chidl:nth-last-child(4) 代表什么?结果是 _一个正好有四个列表项的列表中的第一项_,ok,再结合兄弟选择符~来命中它之后的每一项,就可以达到这样一个目标在正好包含四个列表项的时候,命中它的每一项

li:first-child:nth-last-child(4),
li:first-child:nth-last-child(4) ~ li {
  
    background: red;
}
登录后复制

结合 SASS,将其简化复用

/*定义混合器*/
@mixin n-items($n){
    &:first-child:nth-last-child(#{$n}),
    &:first-child:nth-last-child(#{$n}) ~ &{
        @content;
    }
}

/*调用*/
li {
    @include n-items(4){
        /*属性与值写在这里*/
        background: red;
    }
}
登录后复制

:nth-child()

nth-child()的强大之处在于以接受an+b形式的表达式,那么自然便可以使用其变种 nth-child(n+4) 这种形式,它将会选择除了第1,2,3个子元素之外的所有子元素。

ul li:first-child:nth-last-child(n+4),
ul li:first-child:nth-last-child(n+4) ~ li{
    /*当列表中至少包含四项时,命中包括该项之后的所有列表项*/
}
登录后复制

当然,不止于此,:nth-child()的玩法完全取决于你的脑洞。

0x02 calc

有时,若需要去实现一个 背景宽度满屏,内容宽度固定 的布局,也许我们会去这样设计 DOM 结构

<footer>
    <p class="wrapper">        
    </p>
</footer>
登录后复制

CSS 样式:

footer{
    background: #333;
}

.wrapper{
    max-width: 900px;
    margin: 1em auto;
    height: 200px;
}
登录后复制

使用 calc() 方法以后,就不必如此麻烦了,我们只需三行代码即可实现:

footer{
  background:#333;
  padding:1em calc(50% - 50px);
 }
登录后复制

使用了 clac() 便可以在 CSS 中进行简单的算术运行,这使得 DOM 结构变得非常简洁,没有任何的冗余,当然,缺点也是显而易见的,这里的代码只会在 footer 元素的父级超过 900 px 才会看出效果。

calc() 中的百分比是基于其父级进行解析的

但,我们初次了解到了CSS3 中cacl() 这个魔法技巧。

0x03 垂直居中

基于绝对定位的解决方案

CSS 中有一个很常见的现象,真正的解决方法往往来自于我们最意想不到的地方。比如,可以结合 positon:absolute 和 transform:translate() 属性来实现垂直居中

因为 translate() 变形函数中的百分比是根据这个元素自身的宽度和高度为基准进行换算的,如此一来,便可以彻底解除对固定尺寸的依赖。

示例:DOM 结构

<body>
    <p class="main">
        <h1>Am i center?</h1>
        <p>Center me ,please!</p>
    </p>
</body>
登录后复制

CSS代码:

.main{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}
登录后复制

CSS结构与布局

不过,该方法也是存在不足的:
1.在某些浏览器中,可能会导致模糊显示,因为元素有可能被放置在半个像素上。
2.在并不适合使用绝对定位的情况下。而且绝对定位对整个布局的影响也太过强烈。

基于 FlexBox 的解决方案

毫无疑问,这算是目前最佳的解决方案了。并且,现代浏览器对 FlexBox 的支持已经相当高了。

对基于 FlexBox 容器的 items 使用 margin:auto 不仅可以在水平方向方居中,垂直方向上亦是如此,即使不指定任何宽度,因为这个元素分配到的宽度等于 max-content.

CSS结构与布局

FlexBox 的另一个好处是可以文本也进行垂直居中, 只需对使用display:flex 的元素添加 align-items:center 和 justify-content:center。

.main{
    background: deeppink;
    width: 50%;
    height: 50%;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
登录后复制

CSS结构与布局

0x04 紧贴底部的页脚

有时,我们期望页头和页脚的高度由其内部因素来决定,而内容区块的高度可以自动收缩并占满所有可用的空间。同样,利用 FlexBox 这很容易。

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

    header{
        /*heaer style*/
    }
    
    .main{
        flex:1;
    }

    footer{
        /*footer style*/
    }
}
登录后复制

我们给了 body 一个 min-height:100vh 的高度这样它至少会占据整个视口的高度,然后赋予 main 一个大于 0 的 flex 值就可以了。

问题:如果页脚是固定在屏幕的底部的呢?如何解决当页面滚动到最后的时候保证页脚不会覆盖内容区?

对于这个问题,纯属个人想法,可以在 footer 之后添加一个 p#_footer。

此时的 DOM 结构如下:

<body>
    <header><header>
    <p class="main"></p>
    <footer></footer>
    <p id="_footer"></p>
</body>
登录后复制

而对于 p#_footer 而言,不需要为其中添加任何的内容和样式,只需要它的高度等于 footer 的高度就可以了,而对于这点,使用 jQuery 就可以轻松搞定。

$('#_footer').height($('footer').height())
登录后复制

如此,对于响应布局也可以不用担心了,虽然有点点hack,但也算完美的解决了,Bingo!


更多CSS结构与布局 相关文章请关注PHP中文网!


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

bootstrap按钮怎么用 bootstrap按钮怎么用 Apr 07, 2025 pm 03:09 PM

如何使用 Bootstrap 按钮?引入 Bootstrap CSS创建按钮元素并添加 Bootstrap 按钮类添加按钮文本

bootstrap怎么调整大小 bootstrap怎么调整大小 Apr 07, 2025 pm 03:18 PM

要调整 Bootstrap 中元素大小,可以使用尺寸类,具体包括:调整宽度:.col-、.w-、.mw-调整高度:.h-、.min-h-、.max-h-

bootstrap怎么看日期 bootstrap怎么看日期 Apr 07, 2025 pm 03:03 PM

答案:可以使用 Bootstrap 的日期选择器组件在页面中查看日期。步骤:引入 Bootstrap 框架。在 HTML 中创建日期选择器输入框。Bootstrap 将自动为选择器添加样式。使用 JavaScript 获取选定的日期。

bootstrap怎么插入图片 bootstrap怎么插入图片 Apr 07, 2025 pm 03:30 PM

在 Bootstrap 中插入图片有以下几种方法:直接插入图片,使用 HTML 的 img 标签。使用 Bootstrap 图像组件,可以提供响应式图片和更多样式。设置图片大小,使用 img-fluid 类可以使图片自适应。设置边框,使用 img-bordered 类。设置圆角,使用 img-rounded 类。设置阴影,使用 shadow 类。调整图片大小和位置,使用 CSS 样式。使用背景图片,使用 background-image CSS 属性。

bootstrap怎么写分割线 bootstrap怎么写分割线 Apr 07, 2025 pm 03:12 PM

创建 Bootstrap 分割线有两种方法:使用 标签,可创建水平分割线。使用 CSS border 属性,可创建自定义样式的分割线。

bootstrap怎么设置框架 bootstrap怎么设置框架 Apr 07, 2025 pm 03:27 PM

要设置 Bootstrap 框架,需要按照以下步骤:1. 通过 CDN 引用 Bootstrap 文件;2. 下载文件并将其托管在自己的服务器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根据需要编译 Sass/Less;5. 导入定制文件(可选)。设置完成后,即可使用 Bootstrap 的网格系统、组件和样式创建响应式网站和应用程序。

bootstrap日期怎么验证 bootstrap日期怎么验证 Apr 07, 2025 pm 03:06 PM

在 Bootstrap 中验证日期,需遵循以下步骤:引入必需的脚本和样式;初始化日期选择器组件;设置 data-bv-date 属性以启用验证;配置验证规则(如日期格式、错误消息等);集成 Bootstrap 验证框架,并在表单提交时自动验证日期输入。

bootstrap导航栏怎么设置 bootstrap导航栏怎么设置 Apr 07, 2025 pm 01:51 PM

Bootstrap 提供了设置导航栏的简单指南:引入 Bootstrap 库创建导航栏容器添加品牌标识创建导航链接添加其他元素(可选)调整样式(可选)

See all articles