使用 CSS media queries 实现多屏幕响应式设计

在当前移动互联网时代,人们使用不同的设备来访问网站,如手机、平板电脑、电脑等。而且设备的屏幕大小也不尽相同,这就对前端工程师提出了响应式设计的要求,即对不同屏幕尺寸适配不同的布局和样式。媒体查询(media queries)是 CSS3 提供的一种利用 CSS 媒体类型和媒体特性,实现样式在特定条件下的应用的技术。下面我们将使用媒体查询实现多屏幕的响应式设计。

基本语法

媒体查询使用 @media 规则包裹一段 CSS 代码,当设备满足媒体查询的条件时,这段 CSS 代码才会生效。基本语法如下:

------ --------- --- -------------------- -
  -- --- ----- --
-

其中,mediatype 表示媒体类型,常见的有 all、print、screen,具体请参考 MDN 文档;mediafeature:value 是媒体特性和值的组合,用于描述设备的属性,如屏幕宽度、设备方向等。

媒体特性与值

媒体特性和值包含很多,下面列举一些常见的:

  • width: 可视区域的宽度
  • height: 可视区域的高度
  • aspect-ratio: 宽高比
  • orientation: 方向,可选值为 portrait 和 landscape
  • device-width: 设备宽度,不包括滚动条和其他用户界面的软件
  • device-height: 设备高度,不包括滚动条和其他用户界面的软件
  • device-aspect-ratio: 设备宽高比,等同于设备宽度除以设备高度
  • color: 颜色位数,可选值为 min-color,max-color 和 exact-color
  • resolution: 设备像素比,可选值为 min-resolution,max-resolution 和 resolution

示例代码

为了更好地说明媒体查询的使用方法,我们可以通过以下示例代码来实现响应式设计。

--------- -----
------
------
  ----- --------------- ---------------------------- -----------------
  ----------------- ------ ---------------
  -------
    -- ------ ------ --
    ---------- -
      ------ ----
      ------- - -----
      -------- -----
      ----------------- --------
    -
    -- -
      ---------- -----
      ------------ -----
      ----------- -------
    -
    - -
      ---------- -----
      ------------ ----
    -
  
    -- ----- ------- --- ----- ------- --
    ------ ----------- ------ -
      ---------- -
        ------ ----
        -------- -----
      -
      -- -
        ---------- -----
      -
      - -
        ---------- -----
      -
    -

    -- ----- ------- --- ------ ------- --
    ------ ----------- ------ --- ----------- ------ -
      ---------- -
        ------ ----
        -------- -----
      -
      -- -
        ---------- -----
      -
      - -
        ---------- -----
      -
    -

    -- ----- ------- --- ----- ------- --
    ------ ----------- ------ -
      -- ----- --------- ----- --- ------- --
      ---------- -
        ------ ----
        -------- -----
      -
      -- -
        ---------- -----
      -
      - -
        ---------- -----
      -
    -
  --------
-------
------
  ---- ------------------
    -------------- ------ ------------
    ------- -- -- ------- -- --- -- --- ----- ------- -- ------ - ---------- ------ --- --------- ------ ----------
  ------
-------
-------

在上面的代码中,我们使用媒体查询设置了针对不同屏幕尺寸的 CSS 样式,如页面宽度小于等于 576px 时,.container 的宽度为 90%、padding 为 10px,h1 的字号为 24px,p 的字号为 16px。

总结

使用 CSS 媒体查询可以很方便地实现多屏幕的响应式设计。前提是设计良好的界面,可以针对设备的不同特性调整布局和样式。如何使用媒体查询,关键在于媒体类型和特性、合理的分割点和合适的样式调整。在实践中,可以参考一些成熟的响应式设计框架,如 Bootstrap、Foundation 等。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6496557148841e98943645f7


猜你喜欢

  • 使用 Enzyme 进行通用的 React 组件测试的细节

    React 组件在现代前端应用中扮演着非常重要的角色。它们负责展示和交互用户界面,提供了在开发过程中进行测试的重要机会。然而,在测试 React 组件时,很难模拟用户与组件之间的交互,这就需要 Enz...

    1 年前
  • Mocha 和 Chai:如何使用 HTML 测试结果报告?

    在前端开发中,测试是至关重要的一部分。Mocha 和 Chai 是两个非常流行的 JavaScript 测试工具,它们能够让开发人员以更高效的方式编写、运行和管理测试用例。

    1 年前
  • ES12 对于大整数运算的支持

    在前端开发中,常常会用到数字计算,包括整数和浮点数的加、减、乘、除等运算。在处理需要精确计算的场合,传统的 JavaScript 中的 Number 类型并不能胜任。

    1 年前
  • PM2 如何实现进程日志的切割和归档处理

    当我们的系统系统线上运行时,对于进程日志的管理是非常重要的。PM2 是一个非常流行的进程管理工具,它不仅提供了进程管理的功能,还有进程日志管理的功能。本文将介绍 PM2 如何实现进程日志的切割和归档处...

    1 年前
  • ES8 中引入的 Object.values() 和 Object.entries() 的使用教程

    在 ES8 中,JavaScript 引入了两个非常实用的方法,分别是 Object.values() 和 Object.entries()。它们可以让我们更方便地获取对象的属性值和键值对。

    1 年前
  • Cypress 自动化测试实战:无头浏览器测试篇

    本文将介绍使用 Cypress 对前端应用进行无头浏览器测试的基本流程和技术要点,并提供实例代码和指导建议。希望能帮助读者快速上手和应用 Cypress 进行自动化测试。

    1 年前
  • CSS Flexbox 实现自适应的表格布局的方法

    在前端开发中,经常需要实现表格布局,传统的表格布局需要通过 table 标签来实现,但是 table 标签在响应式布局中的弹性不够,难以兼容移动端设备。而 CSS Flexbox 布局则能很好地解决这...

    1 年前
  • PWA 实现中如何处理图片的加载和缓存?

    Progressive Web App (PWA) 是一种有效提升 Web 应用体验的技术方案,其中,图片是 Web 应用中不可或缺的资源之一。PWA 实现中,对于图片的加载和缓存需要做出特殊的处理。

    1 年前
  • Next.js API 路由的使用方式

    随着互联网技术的不断发展,前端领域也不断壮大。Next.js 是一个 React 应用框架,可帮助前端开发人员更快地构建企业级 React 应用程序。而其中的 API 路由可以使我们更方便地构建自己的...

    1 年前
  • Headless CMS 与微信小程序集成

    在当今互联网时代,快速、高效地构建一个交互式、具有良好用户体验的网站或应用程序是一个至关重要的任务。Headless CMS (无头 CMS) 是目前流行的一种现代内容管理方式,它提供了灵活的 API...

    1 年前
  • Jest + Puppeteer 测试 Vue SSR 项目

    随着前端技术的不断发展,Vue SSR(服务器端渲染)已经被广泛应用于实现更快的首次加载和更友好的 SEO,但同时也带来了新的测试问题。在 SSR 环境下,前端和后端的界限变得模糊,如何进行有效的测试...

    1 年前
  • 无障碍设计在国际化贸易中的影响与优化

    随着全球贸易的逐渐发展,越来越多的企业涉足到跨国业务和国际化市场中。在这个背景下,无障碍设计成为了一个越来越重要的话题。本文,我们将会从无障碍设计的基础入手,探讨无障碍设计在国际化贸易中的影响与优化,...

    1 年前
  • 如何使用 Hapi.js 和 Redis 实现会话管理

    随着 Web 应用程序的增长和用户交互的增加,许多应用程序需要管理会话以在多个请求之间跟踪用户状态。要做到这一点,Hapi.js 作为流行的 Node.js Web 框架提供了内置的会话管理功能。

    1 年前
  • 如何使用 Babel 进行代码分析和调试

    本文将介绍如何使用 Babel 进行前端代码分析和调试,包括代码转换和语法检查等功能。 什么是 Babel Babel 是一个 JavaScript 编译器,可以将 ES6+ 代码编译成 ES5 或更...

    1 年前
  • ES7 中关于 Rest 参数的新特性及应用

    在 ES6 中,我们已经认识到了“剩余参数”的概念,即使用 Rest 参数将多个函数参数转换成一个数组。而在 ES7 中,Rest 参数又有了新的应用和特性。 Rest 参数的基础用法 首先,我们来回...

    1 年前
  • 了解 ES11 中的 globalThis 全局变量,解决 JavaScript 中不同环境代码兼容性问题

    在编写 JavaScript 代码时,我们经常会面对不同环境导致的兼容性问题。例如,在浏览器中使用 window 对象来访问全局变量,但在 Node.js 环境中,却应该使用 global 对象。

    1 年前
  • 如何使用 Tailwind CSS 实现圆角、阴影等效果

    简介 Tailwind 是一个基于原子类的 CSS 框架,使用非常简便,只需要在 HTML 标记中加入 Tailwind 提供的 CSS 类名即可实现各种布局和样式效果。

    1 年前
  • React Native 中使用 ImagePicker 实现图片选择

    作为一款跨平台移动应用程序框架,React Native 在移动应用的开发中具有广泛的应用。其中,对于图片选择的功能,在移动应用的开发中也是非常常见的需求。 React Native 提供了 Imag...

    1 年前
  • Koa2 实现 WebSocket 详解

    简介 WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,使得客户端和服务器可以进行实时通信。Koa2 是一个优秀的 Node.js web 开发框架,可以方便地使用中间件实现 We...

    1 年前
  • ES10 中的 Object.fromEntries 方法实现简单的二维数组转对象

    在前端开发中,我们经常要对不同类型的数据进行转换操作。其中,将二维数组转换成对象是常见的操作之一。在 ECMAScript 2019 标准(ES10)中,新加入的 Object.fromEntries...

    1 年前

相关推荐

    暂无文章