响应式CSS 媒体查询——WEB开发系列39

CSS媒体查询(Media Queries)是响应式设计中的核心技术之一,帮助我们在不同设备上展示不同的样式。通过媒体查询,开发者可以检测用户设备的特性,如屏幕宽度、高度、分辨率、方向等,针对性地调整网页布局。


一、CSS媒体查询基础

1.1 什么是媒体查询?

媒体查询是CSS3引入的一种技术,允许开发者根据用户的设备特性应用不同的样式规则。它不仅可以检测设备的类型,还能检查诸如设备宽度、高度、分辨率等特性。通过媒体查询,可以实现同一页面在不同设备上呈现不同的布局。


1.2 媒体类型(Media Types)

媒体类型是媒体查询中的基础,它定义了应用媒体查询的设备类型。常见的媒体类型包括以下几种:

  • all:适用于所有设备,不限制设备类型。这是默认的媒体类型,即如果没有指定其他类型,媒体查询将应用于所有设备。
  • print:用于打印机或打印预览时应用的样式。这种媒体类型在设计打印样式时非常有用,可以确保页面在打印时格式正确,隐藏一些不必要的内容,如导航栏等。
  • screen:专为屏幕设备设计的样式,适用于电脑、平板、手机等显示屏幕的设备。
  • speech:用于屏幕阅读器等有声设备,帮助为语音输出设备提供优化样式。

示例:

/* 适用于所有设备 */
@media all {
    body {
        font-size: 16px;
    }
}

/* 适用于屏幕设备 */
@media screen {
    body {
        background-color: #f4f4f4;
    }
}

/* 适用于打印机 */
@media print {
    body {
        color: black;
    }
}

1.3 媒体特征规则(Media Features)

媒体特征是媒体查询的核心部分,允许开发者根据设备的特性应用样式。常见的媒体特征包括设备的宽度、高度、分辨率和方向等。以下是几个关键的媒体特征:


1.3.1 宽度和高度(Width & Height)

​width​​和​​height​​​分别表示设备视口的宽度和高度,这两个特征通常用于针对不同设备的尺寸调整布局。例如,手机的屏幕较窄,通常需要在窄屏设备上显示单列布局,而宽屏设备可以显示多列布局。

/* 适用于视口宽度大于等于768px的设备 */
@media screen and (min-width: 768px) {
    body {
        font-size: 18px;
    }
}

/* 适用于视口宽度小于768px的设备 */
@media screen and (max-width: 768px) {
    body {
        font-size: 16px;
    }
}
1.3.2 朝向(Orientation)

​orientation​​媒体特征用于检测设备的屏幕朝向,分为​​portrait​​(竖屏)和​​landscape​​​(横屏)。这对于处理移动设备的屏幕旋转非常有用。

/* 适用于竖屏设备 */
@media screen and (orientation: portrait) {
    body {
        background-color: lightblue;
    }
}

/* 适用于横屏设备 */
@media screen and (orientation: landscape) {
    body {
        background-color: lightcoral;
    }
}
1.3.3 使用指点设备(Pointer)

​pointer​​媒体特征用于检测用户是否使用了指点设备(如鼠标、触控笔)。它有三个可能的值:

  • none:表示设备没有指点能力。
  • coarse:表示设备使用粗略的指点设备,如手指。
  • fine:表示设备使用精确的指点设备,如鼠标。
/* 适用于使用精确指点设备的设备,如鼠标 */
@media (pointer: fine) {
    body {
        cursor: pointer;
    }
}

/* 适用于使用粗略指点设备的设备,如手指 */
@media (pointer: coarse) {
    body {
        cursor: default;
    }
}

二、更复杂的媒体查询

CSS媒体查询不仅可以通过单一特征进行判断,还可以通过逻辑运算符构建更加复杂的查询条件。下面将介绍如何通过“与”、“或”和“非”逻辑组合媒体查询。


2.1 媒体查询中的“与”逻辑(​​and​​)

​and​​​运算符允许开发者组合多个媒体特征,只有当所有特征条件都满足时,样式才会生效。例如,我们可以同时检测设备的宽度和屏幕朝向,只有当设备宽度大于768px且为竖屏时,才应用特定的样式。

/* 适用于宽度大于等于768px且为竖屏的设备 */
@media screen and (min-width: 768px) and (orientation: portrait) {
    body {
        background-color: lightgreen;
    }
}

2.2 媒体查询中的“或”逻辑(​​or​​)

​or​​​运算符可以通过多个查询条件中的任意一个满足条件时应用样式。通过逗号分隔多个条件实现“或”逻辑。

/* 适用于宽度大于等于1024px的设备或横屏设备 */
@media screen and (min-width: 1024px), screen and (orientation: landscape) {
    body {
        background-color: lightyellow;
    }
}

2.3 媒体查询中的“非”逻辑(​​not​​)

​not​​​运算符用于排除某些条件,即当条件不满足时应用样式。

/* 不适用于屏幕设备 */
@media not screen {
    body {
        display: none;
    }
}

三、如何选择断点

断点是媒体查询中定义不同样式的关键点。选择合理的断点可以确保网页在各种设备上表现良好。一般情况下,断点应基于内容,而非设备。常见的做法是根据内容的布局需求设定断点,而不是针对具体设备型号。


3.1 常用断点示例

/* 小屏设备(如手机) */
@media screen and (max-width: 600px) {
    body {
        font-size: 14px;
    }
}

/* 中等屏设备(如平板) */
@media screen and (min-width: 601px) and (max-width: 1024px) {
    body {
        font-size: 16px;
    }
}

/* 大屏设备(如桌面) */
@media screen and (min-width: 1025px) {
    body {
        font-size: 18px;
    }
}

3.2 内容优先原则

选择断点时,应遵循内容优先原则,即根据网页的内容来确定何时需要更改布局。例如,当一个多列布局在较窄的屏幕上变得难以阅读时,这就是一个适合定义断点的时机。


四、移动优先的响应式设计

移动优先(Mobile First)是现代响应式设计的基本理念,指的是首先为移动设备设计页面样式,然后通过媒体查询为更大屏幕设备添加样式。这种设计方式确保页面在小屏设备上的加载和展示更高效,适合当前移动设备用户量大幅增长的趋势。

4.1 移动优先的媒体查询

在移动优先设计中,我们通常使用​​min-width​​​媒体查询,即默认样式适用于所有设备,然后通过断点逐步为更大屏幕的设备添加样式。​

/* 默认样式适用于移动设备 */
body {
    font-size: 14px;
}

/* 适用于平板和桌面设备 */
@media screen and (min-width: 768px) {
    body {
        font-size: 16px;
    }
}

/* 适用于桌面设备 */
@media screen and (min-width: 1024px) {
    body {
        font-size: 18px;
    }
}

可以看到移动设备优先设计的思想,即所有设备默认使用小屏设备的样式,然后针对更大的屏幕逐步增强样式。


如有表述错误及欠缺之处敬请指正补充。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/877521.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

架构师知识梳理(七):软件工程-工程管理与开发模型

软件工程概述 软件开发生命周期 软件定义时期:包括可行性研究和详细需求分析过程,任务是确定软件开发工程必须完成的总目标,具体可分成问题定义、可行性研究、需求分析等。软件开发时期:就是软件的设计与实现,可分成…

气压测试实验(用IIC)

I2C: 如果没有I2c这类总线,连接方法可能会如下图: 单片机所有的通讯协议,无非是建立在引脚(高低电平的变换高低电平持续的时间)这二者的组合上,i2c 多了一个clock线,负责为数据传输打节拍。 (i2…

如何删除git提交记录

今天在提交github时,不小心提交了敏感信息, 不要问我提交了啥,问就是不知道 查了下资料,终于找到简单粗暴的方式来删除提交记录。方法如下 git reset --soft HEAD~i i代表要恢复到多少次提交前的状态,如指定i 2&…

一文读懂:如何将广告融入大型语言模型(LLM)输出

本文是我翻译过来的,讨论了在线广告行业的现状以及如何将大型语言模型(LLM)应用于在线广告。 原文请参见”阅读原文“。 在2024年,预计全球媒体广告支出的69%将流向数字广告市场。这个数字预计到2029年将增长到79%。在Meta的2024…

微服务——网关路由(Spring Cloud Gateway)

网关路由 1.什么是网关 网关又称网间连接器、协议转换器,是在网络层以上实现网络互连的复杂设备,主要用于两个高层协议不同的网络之间的互连。网关就是网络的关口。数据在网络间传输,从一个网络传输到另一网络时就需要经过网关来做数据的路由…

Kafka 基础与架构理解

目录 前言 Kafka 基础概念 消息队列简介:Kafka 与传统消息队列(如 RabbitMQ、ActiveMQ)的对比 Kafka 的组件 Kafka 的工作原理:消息的生产、分发、消费流程 Kafka 系统架构 Kafka 的分布式架构设计 Leader-Follower 机制与…

安卓玩机工具-----无需root权限 卸载 禁用 删除当前机型app应用 ADB玩机工具

ADB玩机工具 ADB AppControl是很实用的安卓手机应用管理工具,无需root权限,通过usb连接电脑后,可以很方便的进行应用程序安装与卸载,还支持提取手机应用apk文件到电脑上,此外还有手机系统垃圾清理、上传文件等…

VMware Workstation Player虚拟机Ubuntu启用Windows共享目录

1、新建共享目录 2、安装并启用vmtools、fuse sudo apt update sudo apt install open-vm-tools open-vm-tools-desktop sudo apt install fuse sudo systemctl start open-vm-tools sudo systemctl enable open-vm-tools 3、命令挂载 sudo vmhgfs-fuse .host:/SharedFold…

初学Linux(学习笔记)

初学Linux(学习笔记) 前言 本文跳过了Linux前期的环境准备,直接从知识点和指令开始。 知识点: 1.目录文件夹(Windows) 2.文件内容属性 3.在Windows当中区分文件类型是通过后缀,而Linux是通过…

leaflet【十】实时增加轨迹点轨迹回放效果实现

实时轨迹回放 在前面有用leaflet-trackplayer实现了一个轨迹回放的效果,单击前往:轨迹回放效果&控制台控制轨迹运动效果 这篇文章主要是实现一下实时增加轨迹点,不改变原来运行轨迹和速度。这里是简易做了一个demo效果,大概…

vue3透传、注入

属性透传 传递给子组件时,没有被子组件消费的属性或事件,常见的如id、class 注意1 1.class、style是合并的,style中如果出现重复的样式,以透传属性为准2.id属性是以透传属性为准,其他情况透传属性名相同&#xff0c…

【AI视频】复刻抖音爆款AI数字人作品初体验

博客主页: [小ᶻZ࿆] 本文专栏: AI视频 | AI数字人 文章目录 💯前言💯抖音上的爆火AI数字人视频💯注册HeyGen账号💯复刻抖音爆款AI数字人💯最终生成效果💯小结 对比原视频效果:…

【算法篇】哈希类(笔记)

目录 一、常见的三种哈希结构 二、LeetCode 练习 1. 有效的字母异位词 2. 两个数组的交集 3. 快乐数 4. 两数之和 5. 四数相加II 6. 赎金信 7. 三数之和 8. 四数之和 一、常见的三种哈希结构 当想使用哈希法来解决问题的时候,一般会选择如下三种数据…

Java--String类

前言: 在之前的学习中,学习了和了解了一些类的基本使用,例如object类等等,但是我们用String这个引用或者说这个类其实我们已经用了好久,只不过没有具体分析过! 对于String类,它可以引用一个字符…

JavaScript web API part3

web API DOM 日期对象 > 得到当前系统的时间 new这个操作就是实例化 语法 const date new Date() or const date new Date(2004-11-3 08:00:00) 可以指定时间 > 可应用于通过系统时间和指定时间实现倒计时的操作 //得到当前时间const date new Date()console.lo…

【Python小知识 - 2】:在VSCode中切换Python解释器版本

文章目录 在VSCode中切换Python解释器版本 在VSCode中切换Python解释器版本 在VSCode中按下快捷键CtrlShiftP,出现命令框。 输入以下命令: Python: Select Interpreter输入命令回车后即出现不同的Python解释器选项,选择想要切换的Python解释器…

【题解】—— LeetCode一周小结37

🌟欢迎来到 我的博客 —— 探索技术的无限可能! 🌟博客的简介(文章目录) 【题解】—— 每日一道题目栏 上接:【题解】—— LeetCode一周小结36 9.合并零之间的节点 题目链接:2181. 合并零之间…

【最新综述】基于深度学习的超声自动无损检测(下)

4.Levels of automation 5.Basic axioms for DL-based ultrasonic NDE 在回顾了最新技术和每个自动化级别的贡献之后,我们不难发现,目前的数字语言方法论在不同论文之间存在着很大的差异。例如,有些作者提出了同时处理不同步骤的模型[121]&…

感知器神经网络

1、原理 感知器是一种前馈人工神经网络,是人工神经网络中的一种典型结构。感知器具有分层结构,信息从输入层进入网络,逐层向前传递至输出层。根据感知器神经元变换函数、隐层数以及权值调整规则的不同,可以形成具有各种功能特点的…

Java并发常见面试题(上)

Java并发常见面试题(上) 什么是线程和进程? 一个 Java 程序的运行是 main 线程和多个其他线程同时运行 进程:程序的一次执行过程,系统运行一个程序就是一个进程从创建,运行到消亡的过程。在Java中启动main函数就是开启一个进程,main函数所…