CSSadvanced

选择器进阶

1.复合选择器
1.1后代选择器

根据html标签的嵌套关系选择父元素后代中满足条件的元素

语法:选择器1 选择器2 {css}

结果:在选择器1所找到的标签的后代(儿、孙、重孙)中,找到满足选择器2的标签设置样式

注意:选择器和选择器之间空格隔开

<title>Document</title>
<style>
    div p {
        /*用空格隔开父子以找到P2*/
        color: red;
    }
</style>
</head>
<body>
    <p>这是P1标签</p>
    <div>
        <p>这是div的儿子P2</p>
    </div>
</body>

此时显示如下:

image-20230708113222555
1.2子代选择器

用大于号隔开,只选择父元素的子代

<title>Document</title>
    <style>
        div>a {
            color: red;
        }
    </style>
</head>
<body>
    <div>
        <!-- div是最高父级 -->
        <a href="#">这是div的儿子a1</a>
        <p>
            <a href="#">这是div的P的孙子a2</a>
        </p>
    </div>
</body>
image-20230708120948889
2.并集选择器

同时选择多组标签设置相同样式

语法:选择器1,选择器2{css} ,即使用逗号隔开

每组选择器可以是基础选择器或复合选择器,每组通常一行写一个以提高可读性

 <title>Document</title>
    <style>
        /*使p、div、span和h1为红色,h2不动*/
        p,
        div,
        span,
        h1{
            color: red;
        }
    </style>
</head>
<body>
    <p>ppp</p>
    <div>divvv</div>
    <span>spppan</span>
    <h1>HHH1</h1>
<!-- 希望只选以上四项为红色 -->
    <h2>HHH2</h2>
</body>
3.交集选择器

选中 同时满足 多个选择器的标签

语法:(连写)选择器1选择器2

既又原则

如果连写里有标签选择器则写最前

4.hover伪类选择器

鼠标悬停状态

`

`

5.Emmet语法

通过简写语法快速生成代码

背景相关属性

  • 颜色

    bgc(Emmett)

    背景颜色默认值透明,背景颜色不影响盒子大小,并且能看清盒子大小和位置,一般在布局中习惯先给盒子设置背景颜色

  • 图片

    bgi

    background-image: url('图片路径')

    url可省略引号、背景图片默认在水平和垂直平铺

    背景图片仅仅给盒子装饰,不能撑开盒子

    [ 结合下面“位置”知识,赋予负值坐标会缺少显示而不会将颜色扩充至外部 ! ]

     div{
                /* 练习使用Emmett语法:w400+h400+bgc */
                width: 400px;
                height: 400px;
                background-color: #fff;
              /*若bgi插入的图片尺寸200*200,则由于上述设置400*400会平铺成四张此图*/  
                background-image: url();
            }
    
  • 平铺

    background-repeat(bgr)(默认xy方向都平铺)

    no-repeat:不平铺

    repeat-x:沿水平方向平铺

    background-repeat:repeat-x

  • 位置
    • bgp,其属性值有二,

    background-position:水平方向位置 垂直方向位置;

    • 后跟的两个位置取值:

      方位名词(最多表示9个)left,center,right&top,center,bottom

      数字+px (坐标系)原点(0,0)盒子左上角、x轴水平向右

      background-position: right bottom ;

      background-position: 50px 100px ;

  • 相关属性连写

    bg 复合属性,一个属性连接多个值,不同于font,此处四项不分先后顺序:

    background: pink url(./images/1.jpg) no-repeat center center

    可以按需省略;

    位置命令如果以单词形式给出,则可以颠倒水平和垂直的顺序;

    特殊情况pc端盒子和图片一样大小可以直接写background: url() ;

    同font连写注意事项:当设置单独的样式和连写,要么把单独样式写在连写以下,要么写在连写以内

情境

img标签和背景图片的区别:现有在网页上展示一张图片的需求,

法一,(产品图)直接写上img。img是一个标签,不设置宽高会默认以原尺寸显示;

法二,(修饰)div+背景图片。需设置div的宽高,因为背景图片只是装饰的css样式;

元素(标签 尖括号)显示模式

块级元素

特点:独占一行,一行只显示一个;

(div)宽度默认父元素(body);

宽度 高度默认由内容展开,可以设置宽高;

代表:div、p、h系列,ul, li, dl, dt, dd... , form, header, nav, footer...

行内元素

特点:一行内显示多个,宽度高度由内容撑开;

不可设置宽高;

代表:a、span、b、u、i、s...

行内块元素

特点:一行显示多个、可设置宽高

代表:input, textarea, button, select...

特殊:img标签内有行内块元素特点,但chrome调试工具显示结果是inline

元素显示模式转换

实现以上三种互相转换

属性 效果 使用频率
display: block 换成 块级
display: inline-block 换成 行内块
display: inline 换成 行内元素 极少
拓展
html嵌套规范:
块级元素一般作为大容器,

可以嵌套:文本、块级元素、行内元素、行内块元素...

但p标签内不要套div、p、h等块级;

a内部可以嵌套任何元素,

但a内不能嵌套a;

CSS特性

继承性
  • 子元素有默认继承父元素的特点(子承父业);

  • 常见继承属性( 文字控制属性 都能继承!):

    1. color
    <style>
    div{
    color:red;
    }
    </style>
    ...以上会对 文字一、属于文字一的文字二 一同生效...
    <body>
    <div>
    这是DIV里的文字一
    <span>这是DIV里的SPAN里面的文字二</span>
    </div>
    
    1. font-style, font-weight, font-size, font-family

    2. text-indent, text-align

    3. line-height

      ......

  • 调试工具判断样式是否可以继承;

  • 继承失效的特殊情况:

    • a标签的color会失效(默认蓝色)

      h标签的font-size会失效(默认标题大小)

层叠性
特性

给同一个标签设置了不同样式→此时样式叠加→共同作用在标签上;

给同一个标签设置了相同样式→此时样式覆盖→最后的样式生效;

注意

样式冲突 时,只有当选择器 优先级相同时 才能通过层叠性判断结果。

综合案例

a{导航$}*5 :以Emmett语法快速调出五组a标签

alt+shift+光标:以选中多行同时编辑

普通导航栏案例:

<title>Document</title>
    <style>
        a{
            text-decoration: none ;
            width: 100px;
            height: 50px;
            /* 此时上述宽高不会起效 ,因为现在还是行内块 ① */
            background-color: red;
            /* 对①进行下行处理 */
            display: inline-block;

            color: white;

            text-align: center;

            line-height: 50px;
            /* 完成上述要求,再命令hover ②*/
        }
        a:hover{
            background-color: orange;
        }
    </style>
</head>
<body>
    <a href="#">导航1</a>
    <a href="#">导航2</a>
    <a href="#">导航3</a>
    <a href="#">导航4</a>
    <a href="#">导航5</a>
</body>
</html>

五彩导航栏案例:

image-20230708171601186
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>七月八日练习</title>
    <style>
        a{
            text-decoration: none;
            /*去下划线*/
             width: 120px;
             height: 58px;
             background-color: pink;
             /*上述不生效,考虑显示模式*/
             display: inline-block;
             /*使其水平、竖直居中:*/
             text-align: center;
             line-height: 58px;
             /*文字颜色:*/
             color: white;
        }
        /*考虑到出于美化而非产品图用途,起用background而非img*/
        /*每个a背景图都不同,单独找到每个a,分别设置背景图。因此起用类名*/
        .one{
            background-image: url(./images/bg1.png);
        }
        .two{
            background-image: url(./images/bg2.png);
        }
        .three{
            background-image: url(./images/bg3.png);
        }
        .four{
            background-image: url(./images/bg4.png);
        }
        .five{
            background-image: url(./images/bg5.png);
        }
        /*-------完成以上后还差hover效果未实现-------*/
        .one:hover{
            background-image: url(./images/bg6.png);
        }
        .two:hover{
            background-image: url(./images/bg7.png);
        }
        .three:hover{
            background-image: url(./images/bg8.png);
        }
        .four:hover{
            background-image: url(./images/bg7.png);
        }
        .five:hover{
            background-image: url(./images/bg6.png);
        }
    </style>
</head>
<body>
    <a href="#" class="one">五</a>
    <a href="#" class="two">彩</a>
    <a href="#" class="three">导</a>
    <a href="#" class="four">航</a>
    <a href="#" class="five">栏</a>
</body>
</html>
posted on 2023-07-08 17:17  言行一  阅读(11)  评论(0编辑  收藏  举报