CSS 媒体查询:从入门到精通,打造跨设备完美体验

        在当今移动互联网时代,用户访问网站的设备早已不再局限于桌面电脑,手机、平板等各种屏幕尺寸的设备层出不穷。为了确保用户在不同设备上都能获得良好的浏览体验,响应式网页设计应运而生。而 CSS 媒体查询,正是实现响应式设计的核心技术之一。

一、什么是 CSS 媒体查询?

        简单来说,CSS 媒体查询 (Media Queries) 是一种 CSS 技术,它允许你根据设备的特定特性(如屏幕宽度、高度、设备方向等)来应用不同的样式规则。这意味着你可以为不同的设备定制不同的布局、字体大小、图片尺寸等,从而实现网页的响应式布局。

二、CSS 媒体查询的基本语法

创建媒体查询

 @media 媒体目标 and 条件 ... 

使用 @media 关键字,配合条件可以让网页在特定设备的特定条件下显示不同的效果。常用于响应式布局

  • 媒体目标:指定媒体类型,例如 screen (屏幕)、print (打印) 等。最常用的是 screen,可以省略。

  • 条件:指定媒体特性,例如 max-width (最大宽度)、min-width (最小宽度)、orientation (方向) 等。

  • orientation:    landscape横向    portrait纵向

常用的媒体特性

以下是一些常用的媒体特性:

  • width / height: 视口(viewport)的宽度/高度

  • max-width / max-height: 视口(viewport)的最大宽度/高度

  • min-width / min-height: 视口(viewport)的最小宽度/高度

  • orientation: 设备方向,landscape (横屏) 或 portrait (竖屏)

  • resolution: 设备分辨率

案例

    .dataDiv{width: 900px;border:1px salmon solid;margin: auto;display: flex;flex-wrap: wrap;justify-content: space-evenly;}.box{width: 250px;height: 200px;background-color: antiquewhite;margin-top: 20px;}/* max-width:1000px 最大宽度到多少的时候 =0~1000px *//* min-width:1000px 最小宽度到多少的时候 =1000~屏幕的极限 *//* 当屏幕尺寸小于600px的时候,box的颜色变成橘色 */@media screen and (max-width:600px){.dataDiv{width: 480px;}.box{background-color: orange;width: 80%;}}/* 当屏幕尺寸大于600,小于9000的时候,box的颜色为紫色 */@media screen and (min-width:600px) and (max-width:900px){.dataDiv{width: 600px;}.box{width: 40%;background-color: purple;}}/* 当屏幕尺寸大于1000px的时候 */@media screen and (min-width:1000px){.dataDiv{width: 900px;}.box{width: 250px;background-color: skyblue;}}<!-- 核心:判断不同尺寸的时候,css用哪一套 --><div class="dataDiv"><div class="box"></div><div class="box"></div><div class="box"></div><div class="box"></div><div class="box"></div><div class="box"></div><div class="box"></div><div class="box"></div><div class="box"></div></div>

运行结果:

屏幕尺寸大于1000px时
 

 屏幕尺寸大于600px,小于900px时

屏幕尺寸小于600px时 

 

 ❗❗注意:可以用外联式来引用css的样式,添加一个media属性设媒体目标和条件,使得代码不混乱,结果清晰。

三、CSS 媒体查询的最佳实践

  • 移动优先: 建议优先编写针对移动设备的样式,然后使用媒体查询为更大的屏幕添加样式。

  • 使用相对单位: 使用 emrem% 等相对单位,可以使你的布局更加灵活。

  • 避免过度使用: 不要为每个细微的屏幕尺寸差异都创建媒体查询,这会导致代码臃肿,难以维护。

四、总结

        CSS 媒体查询是实现响应式网页设计的重要工具,它可以帮助你创建出适应不同设备的网页,为用户提供更好的浏览体验。通过学习和掌握 CSS 媒体查询,你可以打造出更加专业、用户体验更佳的网站。

 

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Python LeetCode 专题】树

LeetCode 题目104. 二叉树的最大深度(gif 图解)方法一:后序遍历(DFS)方法二:层序遍历(BFS)872. 叶子相似的树(DFS 遍历)1448. 统计二叉树中好节点的数目(DFS 遍历)437. 路径总和 III(前缀和 + DFS 回溯)1372. 二叉树中的最长交错路径(DFS)236. 二叉树的最近公共…

Spring有哪些缺点?

大家好&#xff0c;我是锋哥。今天分享关于【Spring有哪些缺点?】面试题。希望对大家有帮助&#xff1b; Spring有哪些缺点? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Spring框架是一个广泛使用的企业级Java开发框架&#xff0c;提供了丰富的功能和强大的灵…

MySQL数据库——索引潜规则(回表查询、索引覆盖、索引下推)

大家好&#xff0c;这里是编程Cookbook。本文详细介绍MySQL索引的三个潜规则——回表查询、索引覆盖、索引下推&#xff0c;以提升数据库的性能。 文章目录 索引回顾聚集索引&#xff08;Clustered Index&#xff09;非聚集索引&#xff08;Secondary Index/辅助索引/二级索引&…

VScode运行后出现黑窗口

原文链接&#xff1a;VScode运行出黑窗口 1.安装插件&#xff1a;C/C Compile Run 2.快捷键【CtrlShiftp】,点击【首选项&#xff1a;打开用户设置】

使用大语言模型(Deepseek)构建一个基于 SQL 数据的问答系统

GitHub代码仓库 架构 从高层次来看&#xff0c;这些系统的步骤如下&#xff1a; 将问题转换为SQL查询&#xff1a;模型将用户输入转换为SQL查询。 执行SQL查询&#xff1a;执行查询。 回答问题&#xff1a;模型根据查询结果响应用户输入。 样本数据 下载样本数据&#xf…

【前端小点】vue3项目内根据主题读取不同文件夹下的图片资源(图片文件)

项目要求实现一键换肤的功能&#xff0c;不仅仅是主题颜色上的替换&#xff0c;还有图片素材的替换&#xff0c;主题颜色替换的方案大同小异&#xff0c;下面仅对图片素材的一件替换进行方法描述。 主要思路 使用本地仓库对当前主题进行存储&#xff0c;系统根据主题去加载不同…

vxe-table实现动态列

vxe-table实现动态列 1.动态列解释2.解决步骤2.1将后端返回的动态列表头&#xff0c;按照格式拼接在固定列表头上2.2将后端返回的列表数据按照键值对格式组装 1.动态列解释 正常列表是有固定的列&#xff1b;我的需求是&#xff0c;最初只知道表格的固定两列&#xff0c;查询数…

Windows 11 使用容器(Docker Podman)

文章目录 背景1、相关网站1.1、WSL1.2、Docker1.3、Podman 2、环境3、安装部署3.1、安装 WSL3.2、Docker3.2.1、Docker Desktop3.2.1.1、安装3.2.1.2、拉取镜像3.2.1.3、启动容器 3.3、Podman3.3.1、安装3.3.2、使用3.3.3、异常处理 总结 背景 Windows 系统中使用容器&#xf…

UE_C++ —— Gameplay Modules

目录 一&#xff0c;Module Creation INI File Setup 二&#xff0c;Multiple Gameplay Modules 三&#xff0c;Limitations 编译成 DLL 的游戏相关类的集合&#xff1b;正如引擎本身由一组模块构成一样&#xff0c;每个游戏也是由一个或多个游戏模块构成的&#xff1b;这些…

蓝桥杯定时器实现led闪烁

step1.配置定时器&#xff0c;TIM1时高级定时&#xff0c;TIM2是通用定时器&#xff0c;用TIM2就行&#xff0c;用内部时钟源&#xff0c;记住相关公式&#xff0c;定时器中断配置时要使能&#xff0c;且生成代码后也要在mian中写使能函数 step2.写代码 配置生成代码后多出的…

二:前端发送POST请求,后端获取数据

接着一&#xff1a;可以通过端口访问公网IP之后 二需要实现&#xff1a;点击飞书多维表格中的按钮&#xff0c;向服务器发送HTTP请求&#xff0c;并执行脚本程序 向服务器发送HTTP请求&#xff1a; 发送请求需要明确一下几个点 请求方法&#xff1a; 由于是向服务器端发送值…

内外网文件传输 安全、可控、便捷的跨网数据传输方案

一、背景与痛点 在内外网隔离的企业网络环境中&#xff0c;员工与外部协作伙伴&#xff08;如钉钉用户&#xff09;的文件传输面临以下挑战&#xff1a; 安全性风险&#xff1a;内外网直连可能导致病毒传播、数据泄露。 操作繁琐&#xff1a;传统方式需频繁切换网络环境&…

elasticsearch在windows上的配置

写在最前面&#xff1a; 上资源 第一步 解压&#xff1a; 第二步 配置两个环境变量 第三步 如果是其他资源需要将标蓝的文件中的内容加一句 xpack.security.enabled: false 不同版本的yaml文件可能配置不同&#xff0c;末尾加这个 xpack.security.enabled: true打开bin目…

OpenCV二值化处理

1.1. 为什么需要二值化操作 二值化操作将灰度图像转换为黑白图像&#xff0c;即将图像中的像素值分为两类&#xff1a;前景&#xff08;通常为白色&#xff0c;值为 255&#xff09;和背景&#xff08;通常为黑色&#xff0c;值为 0&#xff09;。二值化的主要目的是简化图像&…

[Android]浏览器下载的apk文件无法识别无法安装问题

在Android电话机上&#xff0c;用浏览器下载apk进行版本更新&#xff0c;出现下载文件没被识别为apk&#xff0c;导致无法安装问题。 原来的下载链接&#xff1a; https://mojsetup.obs.cn-southwest-2.myhuaweicloud.com/callphone-release-1.0.4.apk 修改后的下载链接&…

如何使用SSH连接设备?很简单!

前言 小白发现最近写的文章都与SSH息息相关&#xff0c;于是就有了这一篇文章&#xff0c;免得在后续的文章又不断重复如何SSH连接设备。 有需要的小伙伴自然就会看到这里&#xff0c;也不会影响到其他小伙伴的阅读体验。 至于文章里的广告嘛……就当是小伙伴们给小白的一点…

【自学嵌入式(9)ESP8266网络服务器的使用】

ESP8266网络服务器的使用 ESP8266WiFi 库① WiFiClass② WiFiClient③ WiFiServer④ WiFiUDP ESP8266WiFiMulti 库① WiFiMulti ESP8266WebServer 库① P8266WebServer 网络服务器实例在浏览器中控制ESP8266指示灯将开发板引脚状态显示在网页中 在之前的文章中&#xff0c;曾经…

pytorch3d安装记录

官方安装教程&#xff1a; https://github.com/facebookresearch/pytorch3d/blob/main/INSTALL.md 通过pip 或conda 可以很容易安装上预编译好的包&#xff0c; 安装过程不会报错&#xff0c; 但是使用的时候就会报各种错误 &#xff0c;原因是预编译好的包跟自己的环境不一定…

【CVPR2024-工业异常检测】PromptAD:与只有正常样本的少样本异常检测的学习提示

代码链接 摘要 摘要写作总结&#xff1a; 1.提出 两个关键点 &#xff08;视觉语言模型【模型】 少量工业异常检测【方向】&#xff09; 2.想要解决的问题 3.针对上述问题&#xff0c;本文提出了一种什么【方法】的什么【应用方面】方法【模型名】 4.具体讲方法的步骤 5.实验…

【PostgreSQL】如何通过调整PostgreSQL配置参数提高数据库性能

如何通过调整PostgreSQL配置参数提高数据库性能 1. 数据库初始性能2. 内存相关参数3. WAL&#xff08;Write-Ahead Logging&#xff09;相关参数4. 并行查询相关参数5. 连接相关参数6. 根据情况调整 1. 数据库初始性能 使用pgbench在更新PostgreSQL数据库配置前先测试下数据库…