0

0

响应式 Web 开发终极指南

聖光之護

聖光之護

发布时间:2024-10-07 17:31:44

|

768人浏览过

|

来源于dev.to

转载

响应式 web 开发终极指南

介绍

以下是如何确保您的设计在任何设备上保持灵活且美观的方法。让我们看一下使 web 应用程序响应式时需要考虑的关键事项。

css 单位

css 提供了多种单位,有时会让人难以选择正确的单位。

  • px:无论屏幕尺寸如何,基于像素的单位都保持不变。
  • %:基于百分比的单位相对于其父元素的大小。
  • vw 和 vh:基于视口宽度/高度的单位相对于视口的宽度/高度。
  • dvw 和 dvh:动态视口宽度和高度单位与 vw 和 vh 类似,但它们会根据视口的变化(即屏幕键盘出现时)进行动态调整。
  • rem:相对于根元素的字体大小,为缩放提供一致的基础。
  • em:相对于当前元素的字体大小,对于组件内缩放很有用。
  • calc():允许您使用不同单位执行计算的函数。例如,calc(100% - 20px) 可以帮助混合相对和绝对单位。

有关 css 单元的完整列表(尽管许多单元很少使用),请查看此 mdn web 文档页面。


响应式图像

有几种方法可以提高网络上的图像响应能力。

使用宽度和高度:自动

通过将最大宽度限制和高度设置为自动,我们可以使图像响应,而无需更改图像的长宽比。


img {
    width: 100%; /* or any fixed width */
    height: auto; 
  }


如果您希望图像缩小,但不要放大到大于其原始大小,请使用 max-width 而不是 width。

使用 img 元素和 srcset

如果您需要针对不同视口大小或分辨率的同一图像的不同版本怎么办?带有 srcset 属性的 响应式 Web 开发终极指南 标签允许浏览器自动选择最适合设备的图像。
请注意,不同版本并不意味着相同的文件,而是经过调整(例如调整大小、压缩)以适应不同设备的图像。


@@##@@


  • 如果视口宽度为600px或更小,浏览器将使用宽度为100vw的small.jpg。浏览器还将使用small.jpg作为后备图像。
  • 如果视口宽度在 601px 到 1200px 之间,浏览器将使用宽度为 75vw 的medium.jpg。
  • 对于任何宽度超过1200px的视口,浏览器将使用宽度为50vw的large.jpg。

使用图片元素和 srcset

如果您需要针对不同视口大小或分辨率的不同图像怎么办?带有 srcset 属性的 元素允许您为不同的视口大小或分辨率定义不同的图像。



  
  
  @@##@@



在此示例中:

  • 如果视口宽度为600px或更小,浏览器将使用small.jpg。
  • 如果视口宽度在 601px 到 1200px 之间,浏览器将使用medium.jpg。
  • 对于任何超过 1200px 的视口宽度,浏览器将使用 large.jpg。

响应式排版

相对单位


html {
    font-size: 16px;
}
.parent {
    font-size: 2rem; /* 32px (2 * 16px) */
}
.child {
    font-size: 0.5em; /* 16px (0.5 * 32px) */
}


  • em 单位是相对于父元素的字体大小。在上面的示例中,子类的字体大小为 16px,因为它是父元素字体大小(32px)的一半。

  • rem 单位是相对于根元素的字体大小 (html) 而言的。在上面的示例中,父类的字体大小为 32px,因为它是根类字体大小(16px)的两倍。

基于视口的单位


h1 {
  font-size: 5vw;
}
h2 {
  font-size: 5vh;
}


  • vw 单位与视口的宽度相关。
  • vh 单位是相对于视口高度的。

夹紧功能

如果您需要使用相对或基于视口的单位但在最小和最大限制范围内怎么办?
例如,我希望我的字体大小相对于视口的宽度,但最小值应为 12px,最大值应为 48px。钳位功能是此类场景的理想选择。


h1 {
  font-size: clamp(12px, 3vw, 48px);
}



响应式布局

弹性盒

如果您需要主要在一维布局中对齐项目怎么办? (行或列)


card 1
card 2
card 3

.card-container {
  display: flex; /* enable flexbox layout */
  justify-content: space-around; /* space evenly between and around cards */
}
.card {
  background-color: black;
  border: 1px solid white;
  color: white;
  text-align: center;
  padding: 20px;
}


在此处了解有关 flexbox 的更多信息

网格

如果您需要主要在二维布局中对齐项目怎么办? (行和列)

ThinkPHP 中文WEB应用开发框架 开发人员指南 PDF格式
ThinkPHP 中文WEB应用开发框架 开发人员指南 PDF格式

ThinkPHP 中文WEB应用开发框架 开发人员指南 PDF格式

下载

card 1
card 2
card 3
card 4

.card-container {
  display: grid; /* enable grid layout */
  grid-template-columns: 1fr 1fr; /* two equal columns */
  grid-template-rows: 1fr 1fr; /* two equal rows */
  gap: 10px; /* space between grid items */
  width: 100%; /* full width of the container */
}
.card {
  background-color: black;
  border: 1px solid white;
  color: white;
  text-align: center;
  padding: 20px;
}


在这里阅读有关网格的更多信息


媒体查询

如果您想在设备满足特定条件时应用特定样式怎么办?最常见的是,这些条件与设备的宽度有关。


card 1
card 2
card 3

.card-container {
  display: flex;
  flex-direction: column; /* default: single-column layout */
}

/* media query for tablet devices (min-width: 768px) */
@media (min-width: 768px) {
  .card-container {
    flex-direction: row; /* change to two-column layout */
  }
  .card {
    flex: 1; /* equal width for all cards */
  }
}

/* media query for desktop devices (min-width: 1024px) */
@media (min-width: 1024px) {
  .card {
    flex: 25%; /* each card takes 25% of the width */
  }
}


媒体查询还可以与其他特征一起使用,例如高度、方向、宽高比、分辨率、指针、首选颜色方案和显示模式。

视口元标签





此标签负责向浏览器提供有关如何控制页面尺寸和缩放的说明。 width=device-width 部分设置页面的宽度跟随屏幕宽度,initial-scale=1.0 控制页面首次加载时的缩放级别。

响应式框架和组件库

如果你不想重新发明轮子,有很多响应式框架可以节省时间和精力。

  • bootstrap:一种广泛使用的框架,具有预先设计的组件,用于快速响应式网站开发。

  • tailwind css:实用程序优先的框架,可通过实用程序类实现快速自定义设计。

  • mui:基于 material design 的 react 库,提供响应式预样式组件。

  • shadcn:专注于现代、可访问且可自定义的响应式组件。

  • ant design:阿里巴巴面向企业应用的综合设计系统,以响应式组件为特色。

采用移动优先的方法进行设计

移动优先方法意味着从针对较小屏幕(例如智能手机)的设计开始,然后逐渐为较大屏幕(例如平板电脑和台式机)添加更多功能。通过这种方式,我们确保基本体验在移动设备上运行良好,然后您可以在此基础上为更大的设备构建。


.card-container { /* default code is for mobile view */
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
  padding: 20px;
  gap: 12px;
}

@media (min-width: 768px) { /* queries/cases are for larger views */
  .card-container {
    flex-direction: row;
    gap: 18px;
  }
}


example imageexample image

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

263

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

754

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

760

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

605

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

560

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

395

2023.08.22

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 20万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号