CSS @media 媒体查询

@media 媒体查询是响应式设计的核心工具,允许根据设备特性(如屏幕宽度、高度、方向等)应用不同的 CSS 样式。

一、基本语法

css 复制代码
@media media-type and (media-feature) {
  /* 目标样式规则 */
}
  • 媒体类型(可选):

    • all(默认):所有设备

    • screen:屏幕设备

    • print:打印预览

    • speech:屏幕阅读器

  • 逻辑运算符

    • and:同时满足多个条件

    • ,(逗号):满足任意条件

    • not:排除条件

    • only:防止旧浏览器解析错误

二、常用媒体特性(Media Features)

1.宽度/高度

css 复制代码
/* 最大宽度 */
@media (max-width: 768px) { ... } 

/* 最小宽度 */
@media (min-width: 1200px) { ... }

/* 区间范围 */
@media (min-width: 576px) and (max-width: 992px) { ... }

2.设备方向

css 复制代码
@media (orientation: portrait) { ... } /* 竖屏 */
@media (orientation: landscape) { ... } /* 横屏 */

3.像素密度

css 复制代码
@media (min-resolution: 2dppx) { ... } /* 视网膜屏 */

4.颜色设置

css 复制代码
@media (prefers-color-scheme: dark) { ... } /* 深色模式 */

三、HTML 引入方式

1.CSS 文件内嵌

css 复制代码
@media screen and (max-width: 600px) {
  .container { padding: 10px; }
}

2.<link> 标签引入

css 复制代码
<link rel="stylesheet" media="(min-width: 800px)" href="desktop.css">

四、实用示例

css 复制代码
/* 移动端优先:默认小屏样式 */
.container { width: 100%; }

/* 平板样式 */
@media (min-width: 768px) {
  .container { width: 750px; margin: 0 auto; }
}

/* 桌面样式 */
@media (min-width: 1200px) {
  .container { width: 1170px; }
}

/* 深色模式适配 */
@media (prefers-color-scheme: dark) {
  body { background: #121212; color: #f0f0f0; }
}

五、API 文档摘要

特性 描述 值类型
width/height 视口尺寸 长度(px)
aspect-ratio 宽高比(宽度/高度) 比例(16/9)
resolution 像素密度 dpi/dppx
hover 是否支持悬停 hover/none
pointer 主指针设备精度 fine/coarse

六、最佳实践总结

  1. 移动优先原则 :先写移动端样式,再通过 min-width 逐步增强

  2. 断点选择:常用断点参考:576px(手机)、768px(平板)、992px(小桌面)、1200px(大桌面)

  3. 性能优化

    • 避免在媒体查询中使用高开销属性(如 box-shadow

    • 使用 em 代替 px 提高可访问性

  4. 调试工具:Chrome DevTools 设备模式可模拟各种屏幕尺寸

提示:Bootstrap 等框架的响应式系统正是基于媒体查询实现,开发者可自定义断点参数。

相关推荐
Dragon Wu2 分钟前
Electron Forge集成React Typescript完整步骤
前端·javascript·react.js·typescript·electron·reactjs
芳草萋萋鹦鹉洲哦3 分钟前
【Tailwind】动画解读:Tailwind CSS Animation Examples
前端·css
华仔啊5 分钟前
jQuery 4.0 发布,IE 终于被放弃了
前端·javascript
一心赚狗粮的宇叔10 分钟前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一12 分钟前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo12 分钟前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员13 分钟前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
未来龙皇小蓝24 分钟前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
晓得迷路了38 分钟前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js
顾北121 小时前
AI对话应用接口开发全解析:同步接口+SSE流式+智能体+前端对接
前端·人工智能