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 等框架的响应式系统正是基于媒体查询实现,开发者可自定义断点参数。

相关推荐
刘发财7 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶10 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶10 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
Kagol12 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路14 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide14 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter14 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸15 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live0000016 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉16 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化