CSS字体和背景

1. 字体相关的样式

1. color 用来设置字体颜色

2. font-size 字体的大小

  1. 和font-size相关的单位
    em 相当于当前元素的一个font-size
    rem 相对于根元素的一个font-size

3. font-family 字体族(字体的格式)

  1. 可选值:
    serif 衬线字体
    sans-serif 非衬线字体
    monospace 等宽字体
  2. 指定字体的类别,浏览器会自动使用该类别下的字体
  3. font-family 可以同时指定多个字体,多个字体间使用,隔开
  4. 字体生效时优先使用第一个,第一个无法使用则使用第二个 以此类推

4. font-face可以将服务器中的字体直接提供给用户去使用

  1. 问题:
    1.加载速度
    2.版权
    3.字体格式
  2. 使用
@font-face {
                /* 指定字体的名字 */
            font-family:'myfont' ;
            /* 服务器中字体的路径 */
            src: url('./font/ZCOOLKuaiLe-Regular.ttf') format("truetype");
        }

2. 图标字体(iconfont)

  1. 在网页中经常需要使用一些图标,可以通过图片来引入图标,但是图片大小本身比较大,并且非常的不灵活
  2. 所以在使用图标时,我们还可以将图标直接设置为字体,然后通过font-face的形式来对字体进行引入
  3. 这样我们就可以通过使用字体的形式来使用图标
  4. fontawesome 图标字体库使用步骤

第一种
1.下载 https://fontawesome.com/
2.解压
3.将css和webfonts移动到项目中
4.将css中的all.css引入到网页中
5.使用图标字体
- 直接通过给i标签加类名来使用图标字体
class="fas fa-bell"
class="fab fa-accessible-icon"

第二种
通过伪元素来设置图标字体
1.找到要设置图标的元素通过before或after选中
2.在content中设置字体的编码
3.设置字体的样式
fab:
font-family: 'Font Awesome 5 Brands';
fas:
font-family: 'Font Awesome 5 Free';
font-weight: 900;

li::before{
            content: '\f1b0';
            /* font-family: 'Font Awesome 5 Brands'; */
            font-family: 'Font Awesome 5 Free';
            font-weight: 900; 
        }

第三种:通过实体来使用图标字体:
&#x图标的编码;


3. 行高(line height)

1. 定义

  1. 行高指的是文字占有的实际高度
  2. 可以通过line-height来设置行高,行高可以直接指定一个大小(px em),也可以直接为行高设置一个整数,如果是一个整数的话,行高将会是字体的指定的倍数
  3. 行高经常还用来设置文字的行间距
    行间距 = 行高 - 字体大小
  4. 可以将行高设置为和高度一样的值,使单行文字在一个元素中垂直居中

2. 字体框

  1. 字体框就是字体存在的格子,设置font-size实际上就是在设置字体框的高度
  2. 行高会在字体框的上下平均分配

4. 字体的简写属性font

1. font 可以设置字体相关的所有属性

  1. 语法:
    font: 字体大小/行高 字体族
    行高可以省略不写 如果不写使用默认值

4. 字体的其他样式

  1. font-weight 字重 字体的加粗
    normal 默认值 不加粗
    bold 加粗
  2. font-style 字体的风格
    normal 正常的
    italic 斜体
  3. text-align 文本的水平对齐
    left 左侧对齐
    right 右对齐
    center 居中对齐
    justify 两端对齐
  4. vertical-align 设置元素垂直对齐的方式
    baseline 默认值 基线对齐
    top 顶部对齐
    bottom 底部对齐
    middle 居中对齐
  5. text-decoration 设置文本修饰
    none 什么都没有
    underline 下划线
    line-through 删除线
    overline 上划线
  6. white-space 设置网页如何处理空白
    可选值:
    normal 正常
    nowrap 不换行
    pre 保留空白
  7. text-overflow:设置文本溢出处理
    ellipsis 省略号

5. 背景

1. background-color 设置背景颜色

2. background-image 设置背景图片

  1. 可以同时设置背景图片和背景颜色,这样背景颜色将会成为图片的背景色
  2. 如果背景的图片小于元素,则背景图片会自动在元素中平铺将元素铺满
  3. 如果背景的图片大于元素,将会一个部分背景无法完全显示
  4. 如果背景图片和元素一样大,则会直接正常显示
background-image: url("./img/1.png");

3. background-repeat 用来设置背景的重复方式

  1. 可选值:
    repeat 默认值 ,背景会沿着x轴 y轴双方向重复
    repeat-x 沿着x轴方向重复
    repeat-y 沿着y轴方向重复
    no-repeat 背景图片不重复

4. background-position 用来设置背景图片的位置

  1. 设置方式:
  • 通过 top left right bottom center 几个表示方位的词来设置背景图片的位置
    使用方位词时必须要同时指定两个值,如果只写一个则第二个默认就是center
  • 通过偏移量来指定背景图片的位置:水平方向的偏移量 垂直方向变量
 background-position: -50px 300px;

5. background-clip

  1. 可选值:
    border-box 默认值,背景会出现在边框的下边
    padding-box 背景不会出现在边框,只出现在内容区和内边距
    content-box 背景只会出现在内容区

6. background-origin 背景图片的偏移量计算的原点

padding-box 默认值,background-position从内边距处开始计算
content-box 背景图片的偏移量从内容区处计算
border-box 背景图片的变量从边框处开始计算

7. background-size 设置背景图片的大小

  1. 第一个值表示宽度 第二个值表示高度
    • 如果只写一个,则第二个值默认是 auto
  2. cover 图片的比例不变,将元素铺满
  3. contain 图片比例不变,将图片在元素中完整显示

8. background-attachment 背景图片是否跟随元素移动

  1. 可选值:
    scroll 默认值 背景图片会跟随元素移动
    fixed 背景会固定在页面中,不会随元素移动

8. backgound 背景相关的简写属性,所有背景相关的样式都可以通过该样式来设置,并且该样式没有顺序要求,也没有哪个属性是必须写的

1.注意:

  • background-size必须写在background-position的后边,并且使用/隔开
    background-position/background-size
  • background-origin background-clip 两个样式 ,orgin要在clip的前边

6. 渐变

1. 通过渐变可以设置一些复杂的背景颜色,可以实现从一个颜色向其他颜色过渡的效果,!!渐变是图片,需要通过background-image来设置

2. linear-gradient(),线性渐变,颜色沿着一条直线发生变化(默认从上往下)

  1. 实例
background-image: repeating-linear-gradient(to right ,red, yellow 50px);
  1. 通过这些参数改变方向:
    to left
    to right
    to bottom
    to top
    xxxdeg deg表示转x度数
    xturn 表示转x圈
  2. 渐变可以同时指定多个颜色,多个颜色默认情况下平均分布,也可以手动指定渐变的分布情况,数字是指定从哪里开始
background-image: linear-gradient(red 50px,yellow 100px, green 120px, orange 200px);
  1. repeating-linear-gradient() 可以平铺重复的线性渐变
 background-image: repeating-linear-gradient(to right ,red, yellow 50px);

3. radial-gradient() 径向渐变(中心向四周,放射性的效果)

  1. 默认情况下径向渐变的形状根据元素的形状来计算的
  2. 我们也可以手动指定径向渐变的大小和位置
  3. 语法:
    radial-gradient(大小 at 位置, 颜色 位置 ,颜色 位置 ,颜色 位置)
    大小:
    circle 圆形
    ellipse 椭圆
    closest-side 近边
    closest-corner 近角
    farthest-side 远边
    farthest-corner 远角
    位置:
    top right left center bottom
  4. 实例
 background-image: radial-gradient(farthest-corner at 100px 100px, red , #bfa)

你可能感兴趣的:(CSS字体和背景)