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

相关推荐
二十雨辰1 小时前
歌词滚动效果
前端·css
法医1 小时前
和文心快码做朋友,让编程像“说话”一样简单
前端·文心快码
运维小雅1 小时前
提升复购为什么对品牌很重要?
经验分享·媒体
前端小巷子1 小时前
JS 打造「放大镜 + 缩略图」一体组件
前端·javascript·面试
陈随易1 小时前
适合中国宝宝的AI编程神器,文心快码
前端·后端·node.js
知识分享小能手1 小时前
React学习教程,从入门到精通,React AJAX 语法知识点与案例详解(18)
前端·javascript·vue.js·学习·react.js·ajax·vue3
UrbanJazzerati1 小时前
掌握 DOM 的基础属性与方法:从操作元素到构建动态效果
前端·面试
hashiqimiya2 小时前
html实现右上角有个图标,鼠标移动到该位置出现手型,点击会弹出登录窗口。
前端·html
古夕2 小时前
前端文件下载的三种方式:a标签、Blob、ArrayBuffer
前端·javascript·vue.js
纯真时光2 小时前
Vue3中pinia状态管理库的使用(Composition API 风格)
前端