CSS 中@media查询的工作原理,如何利用它实现不同设备的样式适配

大白话 CSS 中@media查询的工作原理,如何利用它实现不同设备的样式适配

什么是 @media 查询

在网页设计里,不同的设备(像手机、平板、电脑)屏幕尺寸各异。要是只使用一套固定的样式,网页在某些设备上可能就显示得乱七八糟。@media 查询就像是一个"智能开关",能依据设备的特性(比如屏幕宽度、高度、分辨率等)来应用不同的 CSS 样式,从而让网页在各种设备上都能完美显示。

@media 查询的工作原理

@media 查询的核心在于设定一个或多个条件,当设备的特性满足这些条件时,就会应用查询里定义的 CSS 样式。基本的语法如下:

css 复制代码
/* 定义一个媒体查询 */
@media 媒体类型 and (媒体特性) {
    /* 当条件满足时应用的样式 */
    选择器 {
        属性: 值;
    }
}
  • 媒体类型 :用来指定查询适用的设备类型,常见的有 all(所有设备)、screen(屏幕设备,如电脑、手机、平板)、print(打印设备)等。
  • 媒体特性 :这是查询的关键条件,例如 min-width(最小宽度)、max-width(最大宽度)、orientation(设备方向,如 portrait 竖屏、landscape 横屏)等。

如何利用 @media 查询实现不同设备的样式适配

下面通过一个具体的例子来说明如何使用 @media 查询为不同屏幕宽度的设备应用不同的样式。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Media Query Example</title>
    <style>
        /* 全局样式,适用于所有设备 */
        body {
            font-family: Arial, sans-serif;
            background-color: lightblue;
            color: black;
        }

        /* 当屏幕宽度小于等于 600px 时(通常是手机设备),应用以下样式 */
        @media screen and (max-width: 600px) {
            body {
                background-color: lightgreen; /* 将背景颜色改为浅绿色 */
                font-size: 14px; /* 减小字体大小 */
            }
        }

        /* 当屏幕宽度大于 600px 且小于等于 900px 时(通常是平板设备),应用以下样式 */
        @media screen and (min-width: 601px) and (max-width: 900px) {
            body {
                background-color: lightyellow; /* 将背景颜色改为浅黄色 */
                font-size: 16px; /* 调整字体大小 */
            }
        }

        /* 当屏幕宽度大于 900px 时(通常是电脑设备),应用以下样式 */
        @media screen and (min-width: 901px) {
            body {
                background-color: lightcoral; /* 将背景颜色改为浅珊瑚色 */
                font-size: 18px; /* 增大字体大小 */
            }
        }
    </style>
</head>

<body>
    <h1>欢迎来到我的网页!</h1>
    <p>这个网页使用了媒体查询来适配不同的设备。</p>
</body>

</html>

代码解释

  1. 全局样式
css 复制代码
/* 全局样式,适用于所有设备 */
body {
    font-family: Arial, sans-serif;
    background-color: lightblue;
    color: black;
}

这部分样式是全局的,会应用到所有设备上。

  1. 手机设备样式(屏幕宽度小于等于 600px)
css 复制代码
/* 当屏幕宽度小于等于 600px 时(通常是手机设备),应用以下样式 */
@media screen and (max-width: 600px) {
    body {
        background-color: lightgreen; /* 将背景颜色改为浅绿色 */
        font-size: 14px; /* 减小字体大小 */
    }
}

当设备屏幕宽度小于等于 600px 时,会将页面的背景颜色改为浅绿色,字体大小减小到 14px。

  1. 平板设备样式(屏幕宽度大于 600px 且小于等于 900px)
css 复制代码
/* 当屏幕宽度大于 600px 且小于等于 900px 时(通常是平板设备),应用以下样式 */
@media screen and (min-width: 601px) and (max-width: 900px) {
    body {
        background-color: lightyellow; /* 将背景颜色改为浅黄色 */
        font-size: 16px; /* 调整字体大小 */
    }
}

当设备屏幕宽度在 601px 到 900px 之间时,会将页面的背景颜色改为浅黄色,字体大小调整为 16px。

  1. 电脑设备样式(屏幕宽度大于 900px)
css 复制代码
/* 当屏幕宽度大于 900px 时(通常是电脑设备),应用以下样式 */
@media screen and (min-width: 901px) {
    body {
        background-color: lightcoral; /* 将背景颜色改为浅珊瑚色 */
        font-size: 18px; /* 增大字体大小 */
    }
}

当设备屏幕宽度大于 900px 时,会将页面的背景颜色改为浅珊瑚色,字体大小增大到 18px。

通过这种方式,我们可以根据不同设备的屏幕宽度来动态调整网页的样式,实现不同设备的样式适配。

相关推荐
小白的代码日记10 分钟前
使用 ECharts 实现小区住户数量统计柱状图
前端·javascript·echarts
小白白一枚11112 分钟前
promise类方法
前端·javascript
小桥风满袖12 分钟前
Three.js-硬要自学系列40之专项学习缓冲几何体法线属性
前端·css·three.js
玲小珑12 分钟前
Next.js 教程系列(二十三)Next.js 应用部署策略与 CI/CD
前端·next.js
西柚小萌新14 分钟前
【前端:Html】--1.2.基础语法
前端·html
十五_在努力44 分钟前
Tailwind Css 中使用 Element Plus 主题系统的方案与实现
前端·vue.js
learning_tom44 分钟前
微信小程序重要知识点
前端·apache
江城开朗的豌豆1 小时前
React的onClick:你以为懂了,其实可能用错了!
前端·javascript·react.js
yinuo1 小时前
纯CSS实现进度完成动画效果
前端
前端小巷子1 小时前
高性能 Vue 应用运行时策略
前端·vue.js·面试