当前位置: 首页 > news >正文

CSS 进阶教程:从定位到动画与布局

文章目录

  • 🌟 CSS 进阶教程:从定位到动画与布局
    • 🌟 目录
    • 🌟 1. 定位
      • **Static(默认定位)**
      • **Relative(相对定位)**
      • **Absolute(绝对定位)**
      • **Fixed(固定定位)**
      • **Sticky(粘性定位)**
    • 🌟 2. 层叠规则(z-index)
    • 🌟 3. BFC 和 IFC
      • **BFC(块级格式化上下文)**
      • **IFC(内联格式化上下文)**
    • 🌟 4. CSS3 新特性
      • 响应式布局与媒体查询
        • 媒体查询
      • Flex 布局
      • Grid 布局
      • 瀑布流布局
    • 🌟 5. 动画与过渡
      • 动画
      • 过渡效果
      • 渐变效果
    • 🌟 6. 背景与边框
      • 背景
      • 边框与圆角
    • 🌟 7. 字体与文本
    • 🌟 8. 2D/3D 转换
      • 2D 转换
      • 3D 转换
      • 🔗 相关资源

🌟 CSS 进阶教程:从定位到动画与布局

在学习了 CSS 的基础知识后,本节将涵盖更高级的 CSS 概念和技术,包括定位、布局、动画等,帮助你全面掌握 CSS 的核心功能。


🌟 目录

  1. 定位
  2. 层叠规则(z-index)
  3. BFC 和 IFC
  4. CSS3 新特性
    • 响应式布局
    • 媒体查询
    • Flex 布局
    • Grid 布局
    • 瀑布流布局
  5. 动画与过渡
    • 动画
    • 过渡效果
    • 渐变效果
  6. 背景与边框
    • 背景
    • 边框与圆角
  7. 字体与文本
  8. 2D/3D 转换

🌟 1. 定位

定位决定了元素在页面上的放置方式,CSS 提供了以下几种定位方式:

Static(默认定位)

元素按照正常文档流排列。

css复制代码
div {position: static; /* 默认值 */
}

Relative(相对定位)

相对于自身的原始位置进行偏移。

css复制代码
div {position: relative;top: 20px; /* 相对于原始位置向下偏移 */left: 10px;
}

Absolute(绝对定位)

相对于最近的已定位祖先元素(非 static)进行定位。如果无祖先元素,则相对于 body

css复制代码
div {position: absolute;top: 50px;left: 100px;
}

Fixed(固定定位)

相对于浏览器视口进行定位,滚动页面时位置不变。

css复制代码
div {position: fixed;bottom: 10px;right: 20px;
}

Sticky(粘性定位)

根据滚动位置在 relativefixed 之间切换。

css复制代码
div {position: sticky;top: 0; /* 距离顶部 0 时固定 */
}

🌟 2. 层叠规则(z-index)

z-index 控制元素的堆叠顺序,值越大,元素越靠上。

css复制代码
div {position: absolute;z-index: 10;
}
  • 正整数:比默认层高。
  • 负整数:比默认层低。
  • 默认值为 auto

🌟 3. BFC 和 IFC

BFC(块级格式化上下文)

  • 独立的布局区域,内部元素不会影响外部。
  • 触发方式:
    • overflow: hidden;
    • floatposition: absolute/fixed;
    • display: flex;
css复制代码
.container {overflow: hidden; /* 触发 BFC */
}

IFC(内联格式化上下文)

  • 内联元素形成的一种上下文,布局规则按文字流排列。
html复制代码
<span>这是</span><span>IFC</span>

🌟 4. CSS3 新特性

响应式布局与媒体查询

媒体查询

根据设备宽度、分辨率应用不同样式。

css复制代码
@media (max-width: 600px) {body {background-color: lightblue;}
}

Flex 布局

弹性盒子布局,适合单维方向排列。

css复制代码
.container {display: flex;justify-content: space-between;align-items: center;
}

Grid 布局

强大的二维布局。

css复制代码
.container {display: grid;grid-template-columns: repeat(3, 1fr);grid-gap: 10px;
}

瀑布流布局

css复制代码
.container {column-count: 3; /* 列数 */column-gap: 10px;
}

🌟 5. 动画与过渡

动画

通过 @keyframes 创建复杂动画。

css复制代码
@keyframes slide {from {transform: translateX(0);}to {transform: translateX(100px);}
}div {animation: slide 2s infinite;
}

过渡效果

css复制代码
div {transition: all 0.3s ease-in-out;
}

渐变效果

创建颜色渐变。

css复制代码
div {background: linear-gradient(to right, red, yellow);
}

🌟 6. 背景与边框

背景

背景图像和颜色的设置。

css复制代码
div {background: url('image.jpg') no-repeat center center / cover;
}

边框与圆角

css复制代码
div {border: 2px solid black;border-radius: 10px;
}

🌟 7. 字体与文本

css复制代码
body {font-family: 'Arial', sans-serif;font-size: 16px;
}

🌟 8. 2D/3D 转换

2D 转换

通过 transform 实现旋转、缩放等效果。

css复制代码
div {transform: rotate(45deg) scale(1.2);
}

3D 转换

css复制代码
div {transform: rotateX(45deg) rotateY(30deg);
}

🔗 相关资源

  • CSS官方文档

现在你已经掌握了 CSS 的核心进阶内容,试着实践一下吧!

4o

http://www.lryc.cn/news/504346.html

相关文章:

  • Nginx性能优化全方案:打造一个高效服务器
  • 详解Maven的setting配置文件中mirror和repository的区别
  • 框架模块说明 #07 API加密
  • 安卓BLE蓝牙开发经验分享
  • 后缀表达式有什么场景应用
  • 使用 Kubernetes 部署 Redis 主从及 Sentinel 高可用架构(未做共享存储版)
  • AI开发 - 用GPT写一个GPT应用的真实案例
  • C#—索引器
  • 杨振宁大学物理视频中黄色的字去掉(稳定简洁版本,四)
  • 排序算法(5):归并排序
  • Gate学习(7)引入体素源
  • 2024.12.14 TCP/IP 网络模型有哪几层?
  • item2 for macos
  • 二维三维空间上两点之间的距离
  • 相机测距原理
  • Debezium SchemaNameAdjuster 分析
  • Stable Diffusion绘画 | SDXL模型使用注意事项
  • (五)机器学习 - 数据分布
  • Flink State面试题和参考答案-(上)
  • 利用开源Stable Diffusion模型实现图像压缩比竞争方法用更低的比特率生成更逼真的图像
  • QT信号与槽机制详解
  • openGauss开源数据库实战二十二
  • BurpSuite解决暴力破解时需要验证码问题
  • WPF Combox使用 Text无法选择正确获取CHange后的Text
  • 【速览】设计模式(更新中)
  • 【stable diffusion部署】Stable Diffusion开源本地化的文生图图生图AI
  • 县城楼市踩踏式降价,或现2字头,率先回归月薪一平方的合理价格
  • 计算机组成原理(七):二进制编码
  • 【GitHub分享】you-get项目
  • 论文概览 |《Sustainable Cities and Society》2024.12 Vol.116