理解CSS | 青训营笔记

109 阅读2分钟

理解CSS | 青训营笔记

这是我参与「第四届青训营」笔记创作活动的的第3天。

一、什么是CSS?

CSS 指层叠样式表 (Cascading Style Sheets),它的作用:

  • 用来定义页面元素的样式
  • 设置字体和颜色
  • 设置位置和大小
  • 添加动画效果

二、CSS语法

CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明。

image.png

  • 选择器通常是需要改变样式的 HTML 元素。
  • 每条声明由一个属性和一个值组成。
  • 属性(property)是希望设置的样式属性(style attribute)。每个属性有一个值。属性和值被冒号分开。

可以看出,CSS声明总是以分号 ; 结束,声明总以大括号 {} 括起来。为了让CSS可读性更强,建议每行只描述一个属性。

三、CSS创建

当读到一个样式表时,浏览器会根据它来格式化 HTML 文档。

插入样式表的方法有三种:

  • 外部样式表(External style sheet),简称外链
  • 内部样式表(Internal style sheet),简称嵌入
  • 内联样式(Inline style),简称内联

外链

当样式需要应用于很多页面时,外链将是理想的选择。

在使用外链时,通过改变一个文件来改变整个站点的外观。每个页面使用 <link> 标签链接到样式表。 <link> 标签在(文档的)头部。例如:

<head>
    <link rel="stylesheet" type="text/css" href="style.css">
</head>

浏览器会从文件 style.css 中读到样式声明,并根据它来格式文档。

外部样式表可以在任何文本编辑器中进行编辑。文件不能包含任何的 html 标签。样式表应该以 .css 扩展名进行保存。

嵌入

当单个文档需要特殊的样式时,就应该使用内部样式表。你可以使用 <style> 标签在文档头部定义内部样式表。例如:

<head>
    <style>
        hr {color:sienna;}
        p {margin-left:20px;}
        body {background-image:url("images/back40.gif");}
    </style>
</head>

内联

当样式仅需要在一个元素上应用一次时,可以使用内联样式,可以在相关的标签内使用样式(style)属性。Style 属性可以包含任何 CSS 属性。例如:

<p style="color:sienna;margin-left:20px">Example Content</p>

四、CSS是如何工作的?

graph TD
加载HTML --> 解析HTML
解析HTML --> 加载CSS
加载CSS --> 解析CSS
解析HTML --> 创建DOM树
解析CSS -->|添加样式到DOM节点| 创建DOM树
创建DOM树 --> 展示页面