博主信息
博文 13
粉丝 0
评论 0
访问量 12787
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
选择器,内外边距对盒模型的影响--2019年12时50分
上善若水的博客
原创
852人浏览过

昨天我们说到了css3的选择器,选择器分为基本选择器和扩展选择器。基本选择器包括标签选择器,ID选择器以及类选择器。

还有一个通配选择器。通配选择器用一个星号(*)表示。单独使用时,这个选择器可以与文档中的任何元素匹配,就像一个通配符。虽然通配选择器的功能强大,但是出于效率考虑,很少有人使用它。

今天主要来谈一谈扩展选择器,也有说是高级选择器。其实说法都是无所谓的,重要的是大家要记住他们,并且学会如何使用。

扩展选择器一般包括伪类选择器、属性选择器、相邻选择器、兄弟选择器等

一:属性选择器 匹配具有相同元素属性的元素

如:div[id]:匹配所有具备id属性的div

实例

<!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>选择器</title>
    <style type="text/css">
    ul {
    background-color: lightcyan;
    border: 1px dashed pink;
    margin: 0;
    padding: 0;
    width: 400px;
}

ul li {
    /* 去除数字前方小黑点,也可以使用list-style-type */
    list-style: none;
    width: 30px;
    height: 30px;
    background-color: lightpink;
    border: 1px solid lightgreen;
    /* 设置水平居中和垂直居中 */
    text-align: center;
    line-height: 30px;
    /* 设置圆角 ,单位使用百分比,自适应*/
    border-radius: 50%;
    /* 块级元素变成行内元素 */
    display: inline-block;
}



/* 属性选择性 */

li[id] {
    background-color: goldenrod;
}
    </style>
    <!-- <link rel="stylesheet" href="static/css/demo1.css"> -->
</head>

<body>
    <ul>
        <li id="bg-1">1</li>
        <li class="bg-2">2</li>
        <li id="bg-1">3</li>
        <li class="bg-4">4</li>
        <li class="bg-5">5</li>
        <li class="bg-6">6</li>
        <li id="bg-1">7</li>
        <li id="bg-1">8</li>
    </ul>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

二:相邻(相邻兄弟)选择器

作用:匹配指定元素的相邻【下一个】兄弟元素,前提是他们有相同的父级元素

语法:由 + 号来充当连接符,如 选择器1+选择器2

实例

<!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>选择器</title>
    <style type="text/css">
        ul {
            background-color: lightcyan;
            border: 1px dashed pink;
            margin: 0;
            padding: 0;
            width: 400px;
        }
        
        ul li {
            /* 去除数字前方小黑点,也可以使用list-style-type */
            list-style: none;
            width: 30px;
            height: 30px;
            background-color: lightpink;
            border: 1px solid lightgreen;
            /* 设置水平居中和垂直居中 */
            text-align: center;
            line-height: 30px;
            /* 设置圆角 ,单位使用百分比,自适应*/
            border-radius: 50%;
            /* 块级元素变成行内元素 */
            display: inline-block;
        }
        /* 相邻兄弟选择器(相邻选择器) */
        /* *指所有元素,“+”后面可以加上*也可以加具体的属性名称 */
        
        .bg-2+#bg-3 {
            background-color: green;
        }
    </style>
    <!-- <link rel="stylesheet" href="static/css/demo1.css"> -->
</head>

<body>
    <ul>
        <li id="bg-1">1</li>
        <li class="bg-2">2</li>
        <li id="bg-3">3</li>
        <li class="bg-4">4</li>
        <li class="bg-5">5</li>
        <li class="bg-6">6</li>
        <!-- <li id="bg-1">7</li>
        <li id="bg-1">8</li> -->
    </ul>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

1567573294(1).jpg

三:兄弟(通用兄弟)选择器

作用:匹配到某元素【后面的】 【所有指定】兄弟元素,具有相同的父级元素

语法:由~充当结合符,如 选择器1~选择器2

实例

<!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>选择器</title>
    <style type="text/css">
        ul {
            background-color: lightcyan;
            border: 1px dashed pink;
            margin: 0;
            padding: 0;
            width: 400px;
        }
        
        ul li {
            /* 去除数字前方小黑点,也可以使用list-style-type */
            list-style: none;
            width: 30px;
            height: 30px;
            background-color: lightpink;
            border: 1px solid lightgreen;
            /* 设置水平居中和垂直居中 */
            text-align: center;
            line-height: 30px;
            /* 设置圆角 ,单位使用百分比,自适应*/
            border-radius: 50%;
            /* 块级元素变成行内元素 */
            display: inline-block;
        }
        /* 兄弟选择器(通用兄弟选择器) */
        /* *指所有元素,“~”后面可以加上*也可以加具体的属性名称 */
        
        .bg-4~* {
            background-color: yellow;
        }
    </style>
    <!-- <link rel="stylesheet" href="static/css/demo1.css"> -->
</head>

<body>
    <ul>
        <li id="bg-1">1</li>
        <li class="bg-2">2</li>
        <li id="bg-1">3</li>
        <li class="bg-4">4</li>
        <li class="bg-5">5</li>
        <li class="bg-6">6</li>
        <li id="bg-1">7</li>
        <li id="bg-1">8</li>
    </ul>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例


1567571622(1).jpg

四:伪类选择器

4.1、:first-child     匹配属于父元素中的首个子元素

1567572402(1).jpg       1567572418(1).jpg

4.2、:last-child     匹配属于其父元素中的最后一个子元素

1567573919(1).jpg      1567573948(1).png

4.3、:nth-child(n)匹配属于其父元素中的第n个子元素

1567574255(1).jpg     1567574269(1).jpg

4.4、 :nth-of-type(n)是选择父元素的第n个同类型的子元素 只要前面指定了元素类型

官方解释:

  p:nth-child(2)     选择属于其父元素的第二个子元素的每个 <p> 元素。
  p:nth-of-type(2) 选择属于其父元素第二个 <p> 元素的每个 <p> 元素。

大白话

  p:nth-child(2)  选择p同级元素中的(从前到后的)第二个元素

  p:nth-of-type(2)  选择p同级元素中的第二个p元素

实例

<!DOCTYPE html>
<html>
<head>
<style> 
p:nth-of-type(2)
{
background:#ff0000;
}
</style>
</head>
<body>

<h1>这是标题</h1>
<p>第一个段落。</p>
<p>第二个段落。</p>
<p>第三个段落。</p>
<p>第四个段落。</p>
<p>第五个段落。</p>

</body>
</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

五::nth-child(n)和:nth-of-type(n)区别

关注点不同,如果关注点是位置,就用nth-child(n);如果既关注位置,也关注类型,用nth-of-child(n)

六;padding

3.jpeg

CSS padding 属性定义元素边框与元素内容之间的空白区域,不可见。如果想调整盒子的大小可以调整内容区,内边距,边框。

CSS padding 属性定义元素的内边距。padding 属性接受长度值或百分比值,但不允许使用负值。会强制变成0.

盒子的大小  = content + border + padding + margin

造成padding影响盒子的width或者height的原因是我们在设置css样式的时候给定了width或height,如果没给定,相应的就不会受到padding的影响

6.1宽度分离通过添加一个中间层实现

实例

<!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>内边距</title>
    <link rel="stylesheet" href="static/css/demo2.css">
    <style type="text/css">
        /* 宽度分离 通过增加一个中间层*/
        
        .warp {
            width: 300px;
        }
        
        .box2 {
            padding: 50px;
            border: 1px dashed #e95295;
        }
    </style>
</head>

<body>


    <!-- 宽度分离 -->
    <div class="warp">
        <div class="box2">
            <img src="static/images/girl.jpg" alt="美女" width="200px">
        </div>
    </div>


</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

6.2 box-sizing

实例

<!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>内边距</title>
    <link rel="stylesheet" href="static/css/demo2.css">
    <style type="text/css">
        /* box-sizing */
        
        .box3 {
            box-sizing: border-box;
            background-color: #316745;
            padding: 50px;
            width: 300px;
        }
    </style>
</head>

<body>



    <!-- box-sizing  -->
    <div class="box3">
        <img src="static/images/girl.jpg" alt="美女" width="200px">
    </div>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

七:margin的三大特性:同级塌陷,嵌套传递,自动挤压

7.1同级塌陷

实例

<!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>外边距</title>
    <style type="text/css">
    .box1 {
    width: 100px;
    height: 100px;
    background-color: #884898;
}

.box2 {
    width: 120px;
    height: 120px;
    background-color: #bb5548;
}

.box1 {
    margin-bottom: 60px
}

.box2 {
    margin-top: 30px;
}
    </style>
    <!-- <link rel="stylesheet" href="static/css/demo3.css"> -->
</head>

<body>
    <!-- 同级塌陷 -->
    <div class="box1"></div>
    <div class="box2"></div>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

7.2嵌套传递  将子元素的外边距修改成父元素的内边距并且修改高度

实例

<!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>外边距</title>
    <style type="text/css">
        /* 嵌套传递 */
        /* 将子元素的外边距修改成父元素的内边距并且修改高度 */
        
        .box3 {
            width: 200px;
            height: 200px;
            background-color: #74325c;
        }
        
        .box4 {
            width: 100px;
            height: 100px;
            background-color: #f8b500;
        }
        
        .box3 {
            padding-top: 50px;
            height: 150px;
        }
    </style>
    <!-- <link rel="stylesheet" href="static/css/demo3.css"> -->
</head>

<body>

    <!-- 嵌套传递 -->
    <!-- 将子元素的外边距转换为父元素的内边距并且修改高度 -->
    <div class="box3">
        <div class="box4"></div>
    </div>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

7.3自动挤压


实例

<!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>外边距</title>
    <style type="text/css">
        /* 自动挤压 */
        
        .box5 {
            height: 200px;
            width: 150px;
            background-color: #007b43;
        }
        
        .box5 {
            margin: 30px auto;
        }
    </style>
    <!-- <link rel="stylesheet" href="static/css/demo3.css"> -->
</head>

<body>


    <!-- 自动挤压 -->
    <div class="box5"></div>
</body>

</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例

以上就是选择器、margin以及padding的内容  不忘初心,砥砺前行。






批改状态:合格

老师批语:选择器有很多的, 无法一一实例演示, 不过, 课堂上的几个具有典型性, 一旦掌握 , 其它的就不在话下了
本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学