CSS3 的特性

目录

  • [CSS3 的特性](#CSS3 的特性)
    • [CSS3 的三大特性](#CSS3 的三大特性)
      • [1. 层叠性](#1. 层叠性)
      • [2. 继承性](#2. 继承性)
      • [3. 优先级](#3. 优先级)
    • [CSS3 新增特性](#CSS3 新增特性)
      • [1. 选择器](#1. 选择器)
      • [2. 盒模型](#2. 盒模型)
      • [3. 背景](#3. 背景)
      • [4. 渐变](#4. 渐变)
      • [5. 过渡](#5. 过渡)
      • [6. 动画](#6. 动画)
      • [7. 2D/3D 变换](#7. 2D/3D 变换)
      • [8. 弹性布局](#8. 弹性布局)
      • [9. 网格布局](#9. 网格布局)
      • [10. 媒体查询](#10. 媒体查询)
      • [11. 多列布局](#11. 多列布局)
      • [12. 文字阴影和盒子阴影](#12. 文字阴影和盒子阴影)

CSS3 的特性

CSS3 的三大特性

1. 层叠性

  • 定义:多个 CSS 样式可以同时作用于同一个 HTML 元素
  • 原则
    • 样式冲突时,遵循就近原则
    • 权重不同时,权重高的样式生效
    • 权重相同时,遵循就近原则
  • 示例
css 复制代码
/* 权重相同,就近原则 */
.box {
  color: red;
}
.box {
  color: blue; /* 最终显示蓝色 */
}

/* 权重不同,权重高的生效 */
#box {
  color: red; /* ID选择器权重高,显示红色 */
}
.box {
  color: blue;
}

2. 继承性

  • 定义:子标签会继承父标签的某些样式
  • 特点
    • 子元素可以继承父元素的样式
    • 不是所有属性都可以继承
    • 继承的权重为 0
  • 可继承属性
    • 文本相关:color、font-size、font-family、font-weight、line-height
    • 列表相关:list-style、list-style-type、list-style-position
    • 表格相关:border-collapse、border-spacing
    • 其他:visibility、cursor
  • 不可继承属性
    • 盒模型相关:width、height、margin、padding、border
    • 定位相关:position、top、right、bottom、left
    • 显示相关:display
    • 背景相关:background
  • 示例
css 复制代码
.parent {
  color: red;
  font-size: 16px;
  width: 100px;
}

.child {
  /* 继承 color 和 font-size */
  /* 不继承 width */
}

3. 优先级

  • 定义:不同选择器具有不同的优先级
  • 权重计算
    • 内联样式:1000
    • ID 选择器:100
    • 类选择器、属性选择器、伪类:10
    • 元素选择器、伪元素:1
    • 通配符、子选择器、相邻选择器:0
  • 权重叠加
    • 多个选择器组合时,权重相加
    • 权重相同时,遵循就近原则
  • 示例
css 复制代码
/* 权重计算 */
#box .title {
  /* 100 + 10 = 110 */
  color: red;
}

.box .title {
  /* 10 + 10 = 20 */
  color: blue;
}

/* 权重叠加 */
.box .title span {
  /* 10 + 10 + 1 = 21 */
  color: green;
}

/* !important 优先级最高 */
.title {
  color: red !important; /* 优先级最高 */
}

CSS3 新增特性

1. 选择器

  • 属性选择器

    css 复制代码
    /* 包含属性 */
    [class] {
    }
    
    /* 属性值等于 */
    [class='box'] {
    }
    
    /* 属性值包含 */
    [class*='box'] {
    }
    
    /* 属性值开头 */
    [class^='box'] {
    }
    
    /* 属性值结尾 */
    [class$='box'] {
    }
  • 结构伪类选择器

    css 复制代码
    /* 第一个子元素 */
    :first-child {
    }
    
    /* 最后一个子元素 */
    :last-child {
    }
    
    /* 第n个子元素 */
    :nth-child(n) {
    }
    
    /* 偶数子元素 */
    :nth-child(even) {
    }
    
    /* 奇数子元素 */
    :nth-child(odd) {
    }

2. 盒模型

  • box-sizing

    css 复制代码
    /* 标准盒模型 */
    box-sizing: content-box;
    
    /* IE盒模型 */
    box-sizing: border-box;

3. 背景

  • background-size

    css 复制代码
    /* 覆盖 */
    background-size: cover;
    
    /* 包含 */
    background-size: contain;
    
    /* 具体尺寸 */
    background-size: 100px 100px;
  • background-origin

    css 复制代码
    background-origin: padding-box;
    background-origin: border-box;
    background-origin: content-box;

4. 渐变

  • 线性渐变

    css 复制代码
    background: linear-gradient(to right, red, blue);
    background: linear-gradient(45deg, red, blue);
  • 径向渐变

    css 复制代码
    background: radial-gradient(circle, red, blue);

5. 过渡

  • transition

    css 复制代码
    /* 简写 */
    transition: all 0.3s ease;
    
    /* 分开写 */
    transition-property: width;
    transition-duration: 0.3s;
    transition-timing-function: ease;
    transition-delay: 0s;

6. 动画

  • @keyframes

    css 复制代码
    @keyframes move {
      0% {
        transform: translateX(0);
      }
      100% {
        transform: translateX(100px);
      }
    }
    
    .box {
      animation: move 1s infinite;
    }

7. 2D/3D 变换

  • 2D 变换

    css 复制代码
    /* 位移 */
    transform: translate(100px, 100px);
    
    /* 旋转 */
    transform: rotate(45deg);
    
    /* 缩放 */
    transform: scale(1.5);
    
    /* 倾斜 */
    transform: skew(10deg);
  • 3D 变换

    css 复制代码
    /* 3D位移 */
    transform: translate3d(100px, 100px, 100px);
    
    /* 3D旋转 */
    transform: rotate3d(1, 1, 1, 45deg);
    
    /* 3D缩放 */
    transform: scale3d(1.5, 1.5, 1.5);

8. 弹性布局

  • Flex 布局

    css 复制代码
    /* 容器属性 */
    display: flex;
    flex-direction: row | column;
    justify-content: center | space-between;
    align-items: center;
    flex-wrap: wrap;
    
    /* 项目属性 */
    flex: 1;
    order: 1;
    align-self: center;

9. 网格布局

  • Grid 布局

    css 复制代码
    /* 容器属性 */
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, 1fr);
    grid-gap: 10px;
    
    /* 项目属性 */
    grid-column: span 2;
    grid-row: span 2;

10. 媒体查询

  • 响应式布局

    css 复制代码
    @media screen and (max-width: 768px) {
      .box {
        width: 100%;
      }
    }

11. 多列布局

  • column

    css 复制代码
    .box {
      column-count: 3;
      column-gap: 20px;
      column-rule: 1px solid #ccc;
    }

12. 文字阴影和盒子阴影

  • 阴影效果

    css 复制代码
    /* 文字阴影 */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
    
    /* 盒子阴影 */
    box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
相关推荐
baozj13 小时前
🚀 手动改 500 个文件?不存在的!我用 AST 撸了个 Vue 国际化神器
前端·javascript·vue.js
用户40993225021213 小时前
为什么Vue 3的计算属性能解决模板臃肿、性能优化和双向同步三大痛点?
前端·ai编程·trae
海云前端113 小时前
Vue首屏加速秘籍 组件按需加载真能省一半时间
前端
蛋仔聊测试13 小时前
Playwright 中route 方法模拟测试数据(Mocking)详解
前端·python·测试
零号机13 小时前
使用TRAE 30分钟极速开发一款划词中英互译浏览器插件
前端·人工智能
疯狂踩坑人13 小时前
结合400行mini-react代码,图文解说React原理
前端·react.js·面试
Mintopia13 小时前
🚀 共绩算力:3分钟拥有自己的文生图AI服务-容器化部署 StableDiffusion1.5-WebUI 应用
前端·人工智能·aigc
街尾杂货店&13 小时前
CSS - transition 过渡属性及使用方法(示例代码)
前端·css
CH_X_M14 小时前
为什么在AI对话中选择用sse而不是web socket?
前端
Mintopia14 小时前
🧠 量子计算对AIGC的潜在影响:Web技术的未来可能性
前端·javascript·aigc