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

CSS @media 媒体查询

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

一、基本语法

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

    • all(默认):所有设备

    • screen:屏幕设备

    • print:打印预览

    • speech:屏幕阅读器

  • 逻辑运算符

    • and:同时满足多个条件

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

    • not:排除条件

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

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

1.宽度/高度

/* 最大宽度 */
@media (max-width: 768px) { ... } /* 最小宽度 */
@media (min-width: 1200px) { ... }/* 区间范围 */
@media (min-width: 576px) and (max-width: 992px) { ... }

2.设备方向

@media (orientation: portrait) { ... } /* 竖屏 */
@media (orientation: landscape) { ... } /* 横屏 */

3.像素密度

@media (min-resolution: 2dppx) { ... } /* 视网膜屏 */

4.颜色设置

@media (prefers-color-scheme: dark) { ... } /* 深色模式 */

三、HTML 引入方式

1.CSS 文件内嵌

@media screen and (max-width: 600px) {.container { padding: 10px; }
}

2.<link> 标签引入

<link rel="stylesheet" media="(min-width: 800px)" href="desktop.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 等框架的响应式系统正是基于媒体查询实现,开发者可自定义断点参数。

http://www.dtcms.com/a/345108.html

相关文章:

  • Python从入门到自动化运维
  • 凌霄飞控开发日志兼新手教程——基础篇:认识基本的文件内容和相关函数作用(25电赛备赛版)
  • Quarkus 从入门到精通完整指南Q
  • Python socket远程部署工具服务
  • 云原生作业(k8s总结)
  • 爬虫基础学习-配置代理、以及项目实践
  • Spring Cloud系列—SkyWalking告警和飞书接入
  • CGI-CVE-2016-5385
  • 【实时Linux实战系列】实时网络流量监测与管理
  • tauri配置允许执行eval脚本,在打包cocos游戏web/phone移动端的时候一定要配置
  • canvas绘制图片等比缩放
  • 高边开关+BUCK+MOSFET:48V智能汽车动力链的“黄金三角”
  • Prometheus+Grafana监控mysql
  • AI推理革命:从Sequential Thinking到Agentic AI的演进之路——揭秘大语言模型思维进化的四重奏
  • 【Linux网络编程】Reactor反应堆模式
  • 氙灯市场报告:亚太成增长主力,汽车、医疗、科研多领域需求驱动行业发展
  • 永磁同步电机无速度算法--基于跟踪观测器的脉振正弦注入法
  • 无线数传模块实现:焦化厂四大车与除尘系统无线通讯连锁控制方案案例
  • ComfyUI 原生 REST API 技术文档
  • 视频拼接融合技术:打造全景视界的革命性产品
  • modbus绑定变量,并发送8位数据的办法
  • Vue中的methods 和 computed
  • Linux-Makefile
  • 网络编程6(JVM)
  • 【Redis】哨兵模式和集群模式
  • 红帽认证升级华为openEuler证书活动!
  • 【学习记录】c完整线程池实现
  • 未来已来?AI 预测技术在气象、金融领域的应用现状与风险警示
  • MySQL视图详解:从基础概念到实战案例
  • 人工智能-python-深度学习-软件安装阶段