CSS Fonts(字体)属性用于定义字体系列、大小、粗细和文字样式(如斜体)。
1. 字体系列
CSS使用font-family属性定义文本的字体系列
p { font-family:"微软雅黑"; }
指定多个字体,如果浏览器不支持第一个字体就会尝试下一个直到找到合适的字体,如果都没有,以电脑默认字体为准。
p { font-family: Arial,"Microsoft Yahei", "微软雅黑"; }各种字体之间必须使用英文状态下的逗号隔开
一般情况下,如果有空格隔开的多个单词组成的字体,加引号
2. 字体大小
font-size属性用于设置字号(字体大小)
p { font-size:20px; }
px(像素)大小是我们网页的最常用的单位
谷歌浏览器默认的文字大小为16px
不同浏览器可能默认显示的字号大小不一致,我们尽量给一个明确值大小,不要默认大小。
一般给body指定整个页面文字的大小。
3. 字体粗细
CSS使用font-weight属性设置文本字体的粗细。
p { font-weight:bold; }
属性值
描述
normal
默认值(不加粗的)
bold
定义粗体(加粗的)
100~900
400等同于normal,而700等同于bold 注意这个数字后面不跟单位
示例代码:
<style> .bold { /* font-weight: bold; */ /* 这个700 的后面不要跟单位 等价于bold 都是加粗的效果 */ font-weight: 700; } h2 { font-weight: 400; /* font-weight: normal; */ } </style>4. 文字样式
CSS使用font-style属性设置文本的风格
p { font-style: normal; }
属性值
作用
normal
默认值,浏览器会显示标准的字体样式 font-style:normal;
italic
浏览器会显示斜体的字体样式。
注意:我们很少给文字加斜体,反而要给斜体标签(em, i)改为不倾斜字体。
示例代码:
<style> p { font-style: italic; } em { /* 让倾斜的字体不倾斜 就是赶紧脉动回来 */ font-style: normal; } </style>5. 字体复合属性
字体属性可以把以上的文字样式综合来写,这样可以更节约代码:
body { font: font-style font-weight font-size/line-height font-family; }
使用font属性时,必须按上面语法格式中的顺序书写,不能更换顺序,并且各个属性间以空格隔开
不需要设置的属性可以省略(取默认值),但必须保留font-size和font-family属性,否则font属性将不起作用
示例代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta content="width=device-width, initial-scale=1.0"> <title>CSS字体属性之复合属性</title> <style> /* 想要div文字变倾斜 加粗 字号设置为16像素 并且 是微软雅黑 */ div { /* font-style: italic; font-weight: 700; font-size: 16px; font-family: \'Microsoft YaHei\'; */ /* 复合属性:简写的方式 节约代码*/ /* font:font-style font-weight font-size/line-height font-family; */ /* font: italic 700 16px/20px \'Microsoft YaHei\'; */ font: 20px \'Microsoft YaHei\'; } </style> </head> <body> <div>三生三世十里桃花,一心一意百行代码</div> </body> </html>6. 字体属性总结 属性 表示 注意点
font-size 字号 我们通常用的是px 像素,一定要跟上单位
font-family 字体 实际工作中按照团队约定来写字体
font-weight 字体粗细 记住加粗是700或者bold 不加粗是normal或者400 记住数字不要跟单位
font-style 字体样式 记住倾斜是italic 不倾斜是normal 工作中我们最常用的normal
font 字体连写 1. 字体连写是有顺序的,不能随意换位置 2. 其中字号和字体必须同时出现