CSS布局初级

结构伪类选择器

根据元素在HTML中的结构关系查找元素,减少对HTML中类的依赖,有利于保持代码整洁。常用于查找某父级选择器中的子元素。需要注意的是n可以组成常见的公式

在这里插入图片描述
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>

    /* 1、找到偶数个li------------------------ */
    li:nth-child(2n) {
      /* background-color: orange; */
    }

    li:nth-child(even) {
      /* background-color: blue; */
    }


    /* 2、找到奇数个li------------------------ */
    li:nth-child(2n+1) {
      /* background-color: orange; */
    }

    li:nth-child(2n-1) {
      /* background-color: blue; */
    }

    li:nth-child(odd) {
      /* background-color: pink; */
    }

    /* 3、找到前5个------------------------ */
    li:nth-child(-n+6) {
      /* background-color: orange; */
    }

    /* 4、找到从第5个往后------------------------ */
    li:nth-child(n+5) {
      background-color: red;
    }
    
        /* 1、找到第一个子元素,并且为li标签 */
        
        li:first-child {
            /* background-color: blue; */
        }
        /* 2、找到最后一个子元素,并且为li标签 */
        
        li:last-child {
            /* background-color: orange; */
        }
        /* 3、找到第3个子元素,并且为li标签 */
        
        li:nth-child(3) {
            /* background-color: pink; */
        }
        /* 4、找到倒数第3个子元素,并且为li标签 */
        
        li:nth-child(8) {
            /* background-color: green; */
        }
        
        li:nth-last-child(3) {
            background-color: red;
        }

  </style>
</head>
<body>
  <!-- ul>li{我是第$个li}*10 -->
  <ul>
    <li>我是第1个li</li>
    <li>我是第2个li</li>
    <li>我是第3个li</li>
    <li>我是第4个li</li>
    <li>我是第5个li</li>
    <li>我是第6个li</li>
    <li>我是第7个li</li>
    <li>我是第8个li</li>
    <li>我是第9个li</li>
    <li>我是第10个li</li>
  </ul>
</body>
</html>

易错点:如果找到li中的a标签

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    /* 错误的写法 */
    li a:first-child {
      /* color: red; */
    }

    /* 正确的写法 */
    li:first-child a {
      color: red;
    }
  </style>
</head>
<body>
  <ul>
    <li><a href="#">我是第1个a标签</a></li>
    <li><a href="#">我是第2个a标签</a></li>
    <li><a href="#">我是第3个a标签</a></li>
    <li><a href="#">我是第4个a标签</a></li>
    <li><a href="#">我是第5个a标签</a></li>
    <li><a href="#">我是第6个a标签</a></li>
    <li><a href="#">我是第7个a标签</a></li>
    <li><a href="#">我是第8个a标签</a></li>
  </ul>
</body>
</html>

我们可以把li和first-child想象成交集选择器。前一种的写法意思是找到a的父亲li,找到li的第一个子元素,并且子元素要求为a,那么很明显所有的a都符合这个特征,所以前一种所有a都会变色。后一种写法的意思是找到ul的第一个li 并且规定li中的a元素变色,符合我们的业务需求。

nth-of-type结构伪类选择器。nth-child是直接在所有孩子中数个数,nth-of-type是先通过该类型找到符合的一堆子元素,然后在这一堆子元素中数个数。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        /* 需求:需要找到第3个li标签 */
        /* 1、使用 :nth-child */
        
        li:nth-child(4) {
            /* background-color: red; */
        }
        /* 2、使用 :nth-of-type */
        
        li:nth-of-type(3) {
            background-color: orange;
        }
    </style>
</head>

<body>
    <ul>
        <li>我是第1个li</li>
        <li>我是第2个li</li>
        <div>狸猫</div>
        <li>我是第3个li</li>
        <li>我是第4个li</li>
        <li>我是第5个li</li>
        <li>我是第6个li</li>
        <li>我是第7个li</li>
        <li>我是第8个li</li>
        <li>我是第9个li</li>
        <li>我是第10个li</li>
    </ul>
</body>

</html>

伪元素

一般页面中的非主体内容可以使用伪元素。伪元素是由CSS模拟出的标签效果。
必须设置content属性才能生效,伪元素默认是行内元素

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .father {
      width: 300px;
      height: 300px;
      background-color: skyblue;
    }

    .father::before {
      /* 必加的属性 */
      content: '我是一个伪元素';
      /* 转换显示方式 */
      display: block;
      width: 100px;
      height: 100px;
      background-color: orange;
    }
  </style>
</head>
<body>
  <div class="father">
    我是father内部的内容
  </div>
</body>
</html>

标准流

又称文档流,是浏览器在渲染显示网页内容时默认采用的一套排版规则,规定了应该以何种方式排列元素
对于块级元素,从上往下,垂直布局,独占一行
对于行内元素或者行内块元素,从左往右,水平布局,空间不够自动换行

浮动

  • 浮动的作用

早期作用:图文环绕
现在作用:网页布局。就是让垂直布局的块内盒子变成水平布局,比如一个放在左边,一个放在右边。

  • 浮动的代码

左浮动float:left
右浮动float:right

  • 浮动的特点

浮动元素会脱离标准流,简称脱标,在标准流中不占位置,相当于从地面飘到了空中
浮动元素比标准流高半个级别,可以覆盖标准流中的元素
浮动找浮动,下一个浮动元素会在上一个浮动元素后面左右浮动
浮动元素会受到上面元素边界的影响
浮动元素有特殊的显示效果,一行可以显示多个,可以设置宽高
浮动的元素不能通过text-align:center或者Margin:0 auto 无法让浮动元素水平居中

  • 浮动的案例

网页导航栏案例

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    /* 1、去除标签默认的margin和padding */
    * {
      margin: 0;
      padding: 0;
    }

    /* 2、找到ul,去除小圆点 */
    ul{
      list-style: none;
    }

    /* 3、找到li标签,设置浮动 */
    ul li {
      float: left;
    }

    /* 4、找到a标签,设置宽高 */
    ul li a {
      /* a标签默认是行内元素,不能直接设置宽高 */
      /* 1、转换成行内块元素 */
      /* display: inline-block; */

      /* 2、转换成块级元素 */
      /* display: block; */

      /* 3、设置浮动 */
      float: left;

      width: 80px;
      height: 50px;
      background-color: #ffc0cb;
      text-decoration: none;
      text-align: center;
      line-height: 50px;
      color: #fff;
      font-size: 16px;
    }

    ul li a:hover {
      background-color: #008000;
    }
  </style>
</head>
<body>
  <ul>
    <li><a href="#">新闻1</a></li>
    <li><a href="#">新闻2</a></li>
    <li><a href="#">新闻3</a></li>
    <li><a href="#">新闻4</a></li>
    <li><a href="#">新闻5</a></li>
    <li><a href="#">新闻6</a></li>
    <li><a href="#">新闻7</a></li>
    <li><a href="#">新闻8</a></li>
  </ul>
</body>
</html>

清除浮动

  • 清除浮动的介绍

如果子元素浮动了,此时子元素不能撑开标准流的块级父元素
因为子元素浮动后脱标,不占位置
因此我们需要父元素有高度,从而不影响其他网页元素的布局

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }

    ul{
      list-style: none;
    }

    ul li {
      float: left;
    }

    ul li a {
      float: left;
      width: 80px;
      height: 50px;
      background-color: #ffc0cb;
      text-decoration: none;
      text-align: center;
      line-height: 50px;
      color: #fff;
      font-size: 16px;
    }

    ul li a:hover {
      background-color: #008000;
    }

    .blue {
      width: 800px;
      height: 300px;
      background-color: blue;
    }
  </style>
</head>
<body>
  <ul>
    <li><a href="#">新闻1</a></li>
    <li><a href="#">新闻2</a></li>
    <li><a href="#">新闻3</a></li>
    <li><a href="#">新闻4</a></li>
    <li><a href="#">新闻5</a></li>
    <li><a href="#">新闻6</a></li>
    <li><a href="#">新闻7</a></li>
    <li><a href="#">新闻8</a></li>
  </ul>

  <div class="blue"></div>
</body>
</html>

当把这个代码跑起来之后,你会发现蓝色的盒子被压在了下面,这是为什么呢?是因为ul的li发生了浮动,导致ul没有高度,因此我们需要ul有高度,这样才不会影响其他元素的布局
在这里插入图片描述

  • 清除浮动的五种方法

1 直接设置父元素高度
简单粗暴比较方便,但是有些布局中不能固定父元素的高度,比如京东的推荐模块,每天从后台得到的推荐数据,数据的数量都是不一样的,因此我们无法确定有多少个推荐商品,自然也不可能给一个固定值

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .father {
            height: 400px;/*  */
            width: 400px;
            background-color: pink;
        }
        
        .son {
            float: left;
            width: 100px;
            height: 400px;
            background-color: blue;
        }
    </style>
</head>

<body>
    <div class="father">
        <div class="son"></div>
    </div>
</body>

</html>

2 额外标签法
在父元素内容的最后添加一个块级元素,并且给添加的块级元素设置clear:both
缺点是在页面中会添加额外的标签,会让页面的HTML结构变的更复杂

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .father {
      width: 400px;
      background-color: pink;
    }

    .son {
      float: left;
      width: 100px;
      height: 400px;
      background-color: blue;
    }

    .clear {
      clear: both;
    }
  </style>
</head>
<body>
  <div class="father">
    <div class="son"></div>
    <div class="clear"></div>
  </div>
</body>
</html>

3 单伪元素清除法
用伪元素代替了额外标签,直接给标签加类名即可清除浮动

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .father {
            width: 400px;
            background-color: pink;
        }
        
        .son {
            float: left;
            width: 100px;
            height: 400px;
            background-color: blue;
        }
        
        .clearfix::after {
            content: '';
            display: block;
            clear: both;
            /* 补充代码:在网页中看不到伪元素 */
            /* height: 0;
      visibility: hidden; */
        }
    </style>
</head>

<body>
    <div class="father clearfix">
        <div class="son"></div>
    </div>

</body>

</html>

4 双伪元素清除法

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .father {
      width: 400px;
      background-color: pink;
    }

    .son {
      float: left;
      width: 100px;
      height: 400px;
      background-color: blue;
    }

    .clearfix::before,
    .clearfix::after {
      content: '';
      display: table;
    }
    .clearfix::after {
      clear: both;
    }
  </style>
</head>
<body>
  <div class="father clearfix">
    <div class="son"></div>
  </div>
</body>
</html>

关于双伪元素,我在这里多加一条知识点,以前的章节我们讲到margin塌陷的问题,是因为互相嵌套的块级元素,子元素的margin-top会作用在父元素上。导致父元素一起往下移动。
margin的塌陷问题
同理我们可以用双伪元素解决塌陷问题

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .father {
      width: 400px;
      height: 400px;
      background-color: pink;
    }

    .son {
      width: 100px;
      height: 100px;
      background-color: blue;
      margin-top: 100px;
    }

    .clearfix::before,
    .clearfix::after {
      content: '';
      display: table;
    }
    .clearfix::after {
      clear: both;
    }
  </style>
</head>
<body>
  <div class="father clearfix">
    <div class="son"></div>
  </div>
</body>
</html>

5 给父元素设置overflow:hidden

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .father {
      width: 400px;
      background-color: pink;
      overflow: hidden;
    }

    .son {
      float: left;
      width: 100px;
      height: 400px;
      background-color: blue;
    }
    
  </style>
</head>
<body>
  <div class="father">
    <div class="son"></div>
  </div>
</body>
</html>

BFC的介绍

Block Formatting Context是Web页面的可视CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域
html 浮动元素 行内块元素 overflow属性取值不为visible
BFC盒子常见特点:会默认包裹住内部子元素(标准流,浮动)用来清除浮动
BFC盒子本身与子元素之间不存在margin塌陷现象 用来解决塌陷

这样理解,我们把一个盒子转化成BFC盒子,就可以来清除浮动了(或者用来解决塌陷),比如可以加浮动,变成行内块,或者设置overflow属性,如下所示。这也印证了塌陷问题中的2 3 4 方案的由来

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .father {
      /* 1、把father盒子转换成BFC盒子,解决:清除浮动 */
      /* float: left; */
      /* display: inline-block; */
      overflow: hidden;
      
      width: 400px;
      background-color: pink;
    }

    .son {
      float: left;
      width: 100px;
      height: 400px;
      background-color: blue;
    }
    
  </style>
</head>
<body>
  <div class="father">
    <div class="son"></div>
  </div>
</body>
</html>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清辞-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值