# CSS 选择器
# CSS 基础选择器
基础选择器又包括:标签选择器、类选择器、id 选择器和通配符选择器
# 标签选择器
标签选择器(元素选择器)是指用 HTML 标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的 CSS 样式。
语法: 标签选择器 { 属性:属性值; ...}
作用:标签选择器(元素选择器)是指用 HTML 标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的 CSS 样式。
# 类选择器
如果想要差异化选择不同的标签,单独选一个或者某几个标签,可以使用类选择器
语法: .类名 { 属性1: 属性值1; ...}
结构需要用 class 属性来调用 class 类的意思
<div class="类名"> 变红色 </div>
- 如果想要差异化选择不同的标签,单独选一个或者某几个标签,可以使用类选择器。
- 类选择器在 HTML 中以 class 属性表示,在 CSS 中,类选择器以一个点 “.” 号显示。
- 类选择器使用 “.”(英文点号)进行标识,后面紧跟类名(自定义,我们自己命名的)。
- 可以理解为给这个标签起了一个名字,来表示。
- 长名称或词组可以使用中横线来为选择器命名。
- 不要使用纯数字、中文等命名,尽量使用英文字母来表示。
- 命名要有意义,尽量使别人一眼就知道这个类名的目的。
# 多类名选择器
我们可以给一个标签指定多个类名,从而达到更多的选择目的。 这些类名都可以选出这个标签
简单理解就是一个标签有多个名字
多类名的具体使用: <div class="red font20">亚瑟</div>
注意:
- 在标签 class 属性中写多个类名
- 多个类名中间必须用空格分开
- 这个标签就可以分别具有这些类名的样式
# id 选择器
id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。
HTML 元素以 id 属性来设置 id 选择器,CSS 中 id 选择器以 “#" 来定义。
语法: #id名 { 属性1: 属性值1; }
注意:id 属性只能在每个 HTML 文档中出现一次
# id 选择器和类选择器的区别
- 类选择器(class) 好比人的名字,一个人可以有多个名字,同时一个名字也可以多个人使用。
- id 选择器好比人的身份证号码,全中国是唯一的,不得重复。
- id 选择器和类选择器最大的不同在于使用次数上。
- 类选择器在修改样式中用的最多,id 选择器一般用于页面唯一性的元素上,经常和 JavaScript 搭配使用。
# 通配符选择器:
语法: *{ 属性1: 属性值1; ...}
通配符选择器不需要调用, 自动就给所有的元素使用样式
[attribute]
:选择具有某个属性的所有标签
[attribute=value]
:选择 attribute 值为 value 的所有标签
# 位置伪类选择器
:nth-child(n)
:选择是其父标签第 n 个子元素的所有元素。
# 目标伪类选择器
:target
:当 url 指向该元素时生效。
# 伪元素选择器
将特定内容当做一个元素,选择这些元素的选择器被称为伪元素选择器。
::first-letter
:选择第一个字母
::first-line
:选择第一行
::selection
:选择已被选中的内容
::after
:可以在元素后插入内容
::before
:可以在元素前插入内容
# 选择器总结
基础选择器 | 作用 | 特点 | 使用情况 | 用法 |
---|---|---|---|---|
标签选择器 | 可以选出所有相同的标签,比如 p | 不能差异化选择 | 较多 | · p { color: red; } |
类选择器 | 可以选出 1 个或者多个标签 | 可以根据需求选择 | 非常多 | .nav { color: red } |
id 选择器 | 一次只能选择 1 个标签 | ID 属性只能在每个 HTML 中出现一次 | 一般和 JS 搭配使用 | #nav { color: red; } |
通配符选择器 | 选择所有的标签 | 选择的太多,有部分不需要 | 特殊情况使用 | * {color: red; } |
# CSS 字体属性
# 字体大小
CSS 使用 font-size 属性定义字体大小。
语法: p { font-size: 20px; }
-
px(像素)大小是我们网页的最常用的单位
-
谷歌浏览器默认的文字大小为 16px
-
不同浏览器可能默认显示的字号大小不一致,我们尽量给一个明确值大小,不要默认大小
-
可以给 body 指定整个页面文字的大小
# 字体粗细
CSS 使用 font-weight 属性设置文本字体的粗细。
语法: p { font-weight: bold; }
属性值 | 描述 |
---|---|
normal | 默认的(不加粗的) |
bold | 定义粗体(加粗的) |
100~900 | 400 等同于 normal,而 700 等同于 bold,注意数字后不接单位 |
实际开发时,更喜欢用数字表示粗细
# 字体样式
CSS 使用 font-style 属性设置文本的风格。
语法: p { font-style: normal; }
属性值 | 作用 |
---|---|
normal | 默认值,浏览器会显示标准的字体样式 |
italic | 浏览器会显示斜体的字体样式 |
# 字体的综合写法
字体属性可以把以上文字样式综合来写,这样可以更节约代码:
body { font: font-style font-weight font-size/line-height font-family;}
使用 font 属性时,必须按上面语法格式中的顺序书写,不能更换顺序,并且各个属性间以空格隔开 不需要设置的属性可以省略(取默认值),但必须保留 font-size 和 font-family 属性,否则 font 属性将不起作用
# 字体总结
属性 | 表示 | 注意点 |
---|---|---|
font-size | 字号 | 通常使用单位为 px(像素) |
font-family | 字体 | 实际工作中按照团队约定来写字体 |
font-weight | 字体粗细 | 加粗是 700 或者 bold,不加粗是 normal 或者 400,数字不要跟单位 |
font-style | 字体样式 | 倾斜是 italic ,不倾斜是 normal |
font | 字体连写 | 1. 字体连写是有顺序的,不能随意换位置。2. 字体和字号必须同时出现 |
# CSS 文本属性
# 文本颜色
color 属性用于定义文本的颜色。
语法: div { color: red; }
表示 | 属性值 |
---|---|
预定义的颜色值 | red, pink, blue |
十六进制 | #FF0000, #FF6600, #297D74 |
RGB 代码 | RGB(255, 0, 0), RGB(100%, 0%, 0%) |
最常用的是十六进制
# 文本对齐
text-align 属性用于设置元素内文本内容的水平对齐方式。
语法: div { text-align: center; }
属性值 | 解释 |
---|---|
left | 左对齐(默认值) |
right | 右对齐 |
center | 居中对齐 |
# 修饰文本
语法: div { text-decoration:underline;}
属性值 | 解释 |
---|---|
none | 默认,没有装饰线(最常用) |
underline | 下划线,链接 a 自带下划线(常用) |
overline | 上划线(几乎不用) |
line-through | 删除线(不常用) |
# 文本缩进
语法:
div { | |
text-indent:20px; | |
} | |
div { | |
text-indent:2em; | |
} |
em 是一个相对单位,就是当前元素(font-size) 1 个文字的大小,如果当前元素没有设置大小,则会按照父元素的 1 个文字大小
# 行间距
line-height 属性用于设置行间的距离(行高)。可以控制文字行与行之间的距离
语法: p { line-height: 26px; }
行高的文本:上间距 + 文本高度 + 下间距 = 行间距
# 文本间距
CSS 的 letter-spacing
属性用于设置文本字符的间距。
# 文字阴影
text-shadow
为文字添加阴影。可以为文字与 text-decorations
添加多个阴影,阴影值之间用逗号隔开。每个阴影值由元素在 X 和 Y 方向的偏移量、模糊半径和颜色值组成。
# CSS 样式表
按照 CSS 样式书写的位置(或者引入的方式),CSS 样式表可以分为三大类:
# 行内样式表(行内式)
行内样式表(内联样式表)是在元素标签内部的 style 属性中设定 CSS 样式。适合于修改简单样式.
语法: <div style="color: red; font-size: 12px;">青春不常在,抓紧谈恋爱</div>
- style 其实就是标签的属性,在双引号中间,写法要符合 CSS 规范
- 可以控制当前的标签设置样式
- 由于书写繁琐,并且没有体现出结构与样式相分离的思想,所以不推荐大量使用,只有对当前元素添加简单样式的时候,可以考虑使用
- 使用行内样式表设定 CSS,通常也被称为行内式引入
# 内部样式表(嵌入式)
内部样式表(内嵌样式表)是写到 html 页面内部。是将所有的 CSS 代码抽取出来,单独放到一个 <style>
标签中。
语法:
<style> | |
div { | |
color: red; | |
font-size: 12px; | |
} | |
</style> |
<style>
标签理论上可以放在 HTML 文档的任何地方,但一般会放在文档的<head>
标签中- 通过此种方式,可以方便控制当前整个页面中的元素样式设置
- 代码结构清晰,但是并没有实现结构与样式完全分离
- 使用内部样式表设定 CSS,通常也被称为嵌入式引入,这种方式是我们练习时常用的方式
# 外部样式表(链接式)
实际开发都是外部样式表,适合于样式比较多的情况。
核心是:样式单独写到 CSS 文件中,之后把 CSS 文件引入到 HTML 页面中使用.
引入外部样式表分为两步:
- 新建一个后缀名为 .css 的样式文件,把所有 CSS 代码都放入此文件中。
- 在 HTML 页面中,使用
<link>
标签引入这个文件。
语法: <link rel="stylesheet" href="css文件路径">