CSS

1.css介绍

css指的是层叠样式表(cascading style sheets)

官方文档:https://www.w3school.com.cn/css/index.asp

  • 为什么需要css?
  1. 在没有css之前,我们想要修改html元素的样式需要为每个html元素单独定义样式属性,费心费力。所以css就出现了。
  2. 使用css将html页面的内容与样式分离,提高web开发的工作效率(针对前段开发)
  • css快速入门-例子

    创建html文件完成如下网页显示:

    day03-CSSday03-CSS

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>css快速入门</title>
        <!-- 1.在head标签类出现了<style type="text/css"> </style>
             2.表示要写css内容
             3.div{}表示对div元素进行样式的指定,div就是一个选择器(元素/标签选择器)
             4.width:300px;...等表示对div样式的具体指定,可以有多个
             5.如果有多个使用分号;分开即可,最后的属性后面可以不用分号(建议写上)
             6.当运行页面时,div就会被div{}渲染,修饰
    		 7.在调试css时,可以通过修改颜色或者大小来看样式是否生效
    		 8.css的注解是/* */,快捷键是ctrl+/
         -->
        <style type="text/css">
            div {
                width: 300px;
                height: 100px;
                background-color: beige;
            }
        </style>
    </head>
    <body>
    <div>hello,北京</div>
    <br/>
    <div>hello,上海</div>
    <br/>
    <div>hello,天津</div>
    <br/>
    </body>
    </html>
    

    day03-CSS

2.css语法

  1. css语法可以分成两部分:(1)选择器(2)声明

  2. 声明由属性和值组成,多个声明之间用分号分隔

    day03-CSS

  3. 最后一条声明可以不加分号(建议加上)

  4. 一般每行只描述一个属性

  5. css注释:/*注释内容*/,类似java,快捷键是ctrl+/

3.css常用样式

3.1字体颜色和边框

  • 字体颜色

    颜色可以写颜色名,比如green;也可以写rgb值,比如rgb(200,200,200);十六进制表示值,比如#708090

    day03-CSS

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>颜色</title>
        <style type="text/css">
            div {
                /*三种方式指定颜色:
                1.英文  red;
                2.十六进制 ##ff7d44;
                3.三原色  rgb(255,0,0);
                */
                /*color: red;*/
                /*color: rgb(255,0,0);*/
                color: #ff7d44;
            }
        </style>
    </head>
    <body>
    <div>一只小猫咪</div>
    </body>
    </html>
    

    day03-CSS

  • 边框:属性border

    例子

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>边框</title>
        <style type="text/css">
            div {
                width: 300px;
                height: 100px;
                border: 1px solid blue;/*属性的值的顺序是随意的*/
            }
        </style>
    </head>
    <body>
    <div>一只小猫咪</div>
    </body>
    </html>
    

    day03-CSS

3.2宽度和高度

  • 宽度width和高度height的值,可以用像素:100px,也可以是百分比:50%

    /*width: 300px;*/
    width: 50%;/*百分比*/
    

使用百分比可以自适应浏览器的宽度和高度

3.3背景颜色和字体样式

  • 背景颜色

    属性background-color

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style type="text/css">
            div {
                width: 20%;
                height: 100px;
                background-color: beige;
            }
        </style>
    </head>
    <body>
    <div>hello,北京</div>
    </body>
    </html>
    

    day03-CSS

  • 字体样式

    • font-size:指定大小,可以按照像素大小
    • font-weight:指定是否是粗体
    • font-family:指定类型

    例子

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>字体样式</title>
        <style type="text/css">
            div {
                border: 1px solid black;
                width: 300px;
                font-size: 40px;
                font-weight: bold;
                font-family: 华文新魏; /*选择的字体要是电脑上已经安装的字体*/
            }
        </style>
    </head>
    <body>
    <div>hello,北京</div>
    </body>
    </html>
    

    day03-CSS

3.4div和文本居中

  • div居中

属性margin-left 和 margin-right 都设置为auto的话,表示左右居中

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>div居中显示</title>
    <style type="text/css">
        div {
            /*
            margin-left和margin-right都设置为auto的话,表示左右居中
            */
            margin-left: auto;
            margin-right: auto;
            border: 1px solid black;
            width: 300px;
            font-size: 40px;
            font-weight: bold;
            font-family: 华文新魏;
        }
    </style>
</head>
<body>
<div>hello,北京</div>
</body>
</html>

day03-CSS

  • 文本居中

属性text-align,值为center时表示文本居中

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>文本居中显示</title>
    <style type="text/css">
        div {
            margin-left: auto;
            margin-right: auto;
            border: 1px solid black;
            width: 300px;
            font-size: 40px;
            font-weight: bold;
            font-family: 华文新魏;
            /*文本居中*/
            text-align: center;
        }
    </style>
</head>
<body>
<div>hello,北京</div>
</body>
</html>

day03-CSS

3.5超链接去下划线

属性text-decoration,值为none时表示无修饰

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>超链接去下划线</title>
    <style type="text/css">
        a {
            /* decoration是修饰的意思*/
            text-decoration: none;
        }
    </style>
</head>
<body>
<a href="https://www.baidu.com">点击百度</a>
</body>
</html>

day03-CSS

3.6表格细线

设置边框 : border: 1px solid black

将边框合并: border-collapse: collapse;

指定宽度: width

设置边框: 给 td, th 指定即可 border: 1px solid black;

  1. table, tr, td 表示组合选择器
  2. 就是 table 和 tr 还有 td ,都用统一的样式指定, 可以提高复用性

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>表格细线</title>
    <style type="text/css">
        /*
        设置边框 : border: 1px solid black
        将边框合并: border-collapse: collapse;
        指定宽度: width
        设置边框: 给 td, th 指定即可 border: 1px solid black;
        1. table, tr, td 表示组合选择器
        2. 就是 table 和 tr 还有 td ,都用统一的样式指定, 可以提高复用性
        */
        table, tr, td {
            width: 300px;
            border: 1px solid black;
            border-collapse: collapse;
        }
    </style>
</head>
<body>
<table>
    <tr>
        <td align=center colspan="3">星期一菜谱</td>
    </tr>
    <tr>
        <td rowspan=2>素菜</td>
        <td>青草茄子</td>
        <td>花椒扁豆</td>
    </tr>
    <tr>
        <td>小葱豆腐</td>
        <td>炒白菜</td>
    </tr>
    <tr>
        <td rowspan=2>荤菜</td>
        <td>油闷大虾</td>
        <td>海参鱼翅</td>
    </tr>
    <tr>
        <td>红烧肉</td>
        <td>烤全羊</td>
    </tr>
</table>
</body>
</html>

day03-CSS

3.7列表去修饰

属性list-style的值为none时,表示去掉默认的修饰

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>列表去修饰</title>
    <style type="text/css">
        ul {
            list-style: none;
        }
    </style>
</head>
<body>
<ul>
    <li>三国演义</li>
    <li>红楼梦</li>
    <li>西游记</li>
    <li>水浒传</li>
</ul>
</body>
</html>

day03-CSS

4.css三种使用方式

  • 方式1:在标签的style属性上设置css样式

    问题分析:

    • 标签多了,样式多了,代码量庞大
    • 可读性差,维护麻烦
    • css代码没有复用性

    例子

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>在标签的style属性上设置css样式</title>
    </head>
    <body>
    <div>hello,北京</div>
    <br/>
    <div>hello,上海</div>
    <br/>
    <div>hello,天津</div>
    <br/>
    </body>
    </html>
    

    day03-CSS

  • 方式2:在head标签中,使用style标签来定义需要的css样式

    例子

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>在head标签中,使用style标签来定义需要的css样式</title>
        <style type="text/css">
            div {
                width: 300px;
                height: 100px;
                background-color: beige;
            }
            span {
                border: 1px solid red;
            }
        </style>
    </head>
    <body>
    <div>hello,北京</div>
    <br/>
    <div>hello,上海</div>
    <br/>
    <span>hello,span</span>
    <br/>
    </body>
    </html>
    

    day03-CSS

  • 方式3:把css样式写成单独地css文件,在通过link标签引入(推荐使用)

    例子

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>引入外部的css文件</title>
        <!-- rel:代表relation,关联的意思 -->
        <!-- type="text/css" 这个属性可以不写 -->
        <!-- href表示要引入的css文件的位置,可以是web的完整路径,也可以是相对路径-->
        <!-- 推荐使用第三种方式-->
        <link rel="stylesheet" type="text/css" href="https://www.cnblogs.com/liyuelian/archive/2022/10/29/mycss.css">
    </head>
    <body>
    <div>hello,北京~</div>
    <br/>
    <div>hello,上海</div>
    <br/>
    <span>hello,span</span>
    <br/>
    </body>
    </html>
    
    div {
        width: 200px;
        height: 100px;
        background-color: brown;
    }
    span {
        border: 1px dashed blue;
    }
    

    day03-CSS

5.css选择器

5.1css元素选择器

  1. 最常见的css选择器是元素选择器。换句话说,文档的元素就是最基本的选择器
  2. css元素/标签选择器通常是某个html元素,比如p、h1、a等
  3. 元素选择器会修饰所有的对应的元素

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>元素选择器</title>
    <style type="text/css">
        h1 {
            color: red;
        }
        p {
            color: blue;
        }
    </style>
</head>
<body>
<h1>一只大猫咪</h1>
<p>一只小猫咪</p>
</body>
</html>

day03-CSS

5.2ID选择器

元素选择器会修饰所有的对应的元素,但是假如希望某一个html元素使用特定的样式,而这个元素已经用了元素选择器修饰,这时候就可以使用id选择器来进行特殊的指定

  1. id选择器可以为标有特定id的html元素指定特定的样式
  2. id选择器以#来定义

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>id选择器</title>
    <!--
         1.使用id选择器,需要现在要修饰元素指定id属性,id值是自己指定的
         2.id是唯一的,不能重复
         3.在<style>标签中指定id选择器时,前面需要有#id值
     -->
    <style type="text/css">
        #css1 {
            color: #ff7d44;
        }
        #css2 {
            color: #8A2BE2FF;
        }
    </style>
</head>
<body>
<h1 id="css1">Hello,北京</h1>
<h1 id="css2">hello,上海</h1>
</body>
</html>

day03-CSS

5.3class选择器(类选择器)

假如html文件中有三个div标签:

如果使用元素选择器的话,所有的div元素都会受到影响;

如果使用id选择器的话,可以唯一地修饰其中某一个div元素;

但是如果想要修饰其中两个div,这时就不能用id选择器,因为id选择器只能唯一地修饰一个div元素,也不能使用元素选择器,这时候就需要使用class类选择器。

class类选择器可以在许多元素(不一定是相同的元素)当中,挑选出其中的一部分来进行修饰。

唯一修饰使用id选择器,部分修饰使用类选择器,全部修饰使用元素选择器

  1. class类型选择器,可以通过class属性选择去使用这个样式

  2. 基本语法

    .class 属性值{属性:值;}
    

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>类选择器</title>
    <!--    1.选择class选择器,需要在被修饰的元素上,设置class属性,属性值(名称)自己定义
            2.class属性的值(名称)可以重复
            3.需要在style标签中指定类选择器的具体样式,开头需要使使用.类选择器名称
       -->
    <style type="text/css">
        .css1 {
            color: pink;
        }
        .css2 {
            color: #25d2be;
        }
    </style>
</head>
<body>
<h1 class="css1">Hello,北京</h1>
<h1 class="css1">Hello,world</h1>
<h2 class="css2">ni hao</h2>
<h1 class="css2">hello,上海</h1>
</body>
</html>

day03-CSS

5.4组合选择器

  1. 组合选择器可以让多个选择器共用同一个css样式代码

  2. 语法格式

    选择器1,选择器2,选择器n{属性:值;}
    

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>组合选择器</title>
    <style type="text/css">
        .class01, #id01 {
            width: 300px;
            height: 100px;
            border: 2px solid paleturquoise;
            color: #ff7d44;
        }
    </style>
</head>
<body>
<h1 class="class01">Hello,北京</h1>
<h1 id="id01">hello,上海</h1>
</body>
</html>

day03-CSS

5.5优先级说明

行内样式优先级 > id选择器优先级 > class选择器优先级 > 元素选择器优先级

例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>选择器的优先级说明</title>
    <style type="text/css">
        #id01 {
            color: purple;
        }
        #id02 {
            color: blue;
        }
        .class01 {
            color: red;
        }
        div {
            color: black;
        }
    </style>
</head>
<body>
<h3>选择器的优先级说明</h3>
<!--行内样式的优先级高于id选择器-->
<div id="id01">一只猫猫在睡觉</div>
<!--id选择器的优先级高于类选择器-->
<div id="id02" class="class01">两只猫猫在睡觉</div>
<!--类选择器的优先级高于元素选择器--->
<div class="class01">三只猫猫在睡觉</div>
</body>
</html>

day03-CSS

6.练习

CSS 测验 (w3school.com.cn)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。