为什么是 em 而不是 px?

2023-12-23

我听说你应该在样式表中定义尺寸和距离em而不是以像素为单位。所以问题是我为什么要使用em代替px在 CSS 中定义样式时?有一个很好的例子来说明这一点吗?


说一个比另一个更好的选择是错误的(或者两者都不会在规范中给出自己的目的)。甚至值得注意的是 Stack Overflow 广泛使用 px 单位。这是not这个问题表明这是一个糟糕的选择。

单位的定义

  • px是绝对测量单位(例如in, pt, or cm)这也恰好是 1/96in单位(稍后详细说明原因)。因为它是绝对测量,所以当您想要将某些内容定义为特定大小时,可以随时使用它,而不是与浏览器窗口大小或字体大小等其他内容成比例。

    与所有其他绝对单位一样,px单位不会根据浏览器窗口的宽度进行缩放。因此,如果您的整个页面设计使用绝对单位,例如px而不是%,它不会适应浏览器的宽度。这本身并没有好坏之分,只是设计师需要在坚持精确尺寸和不灵活与拉伸之间做出选择,但在此过程中不遵循精确尺寸。站点通常混合有固定大小和灵活大小的对象。

    通常需要将固定大小的元素合并到页面中 - 例如广告横幅、徽标或图标。这确保您几乎总是需要至少some设计中基于 px 的测量。例如,图像(默认情况下)将被缩放以使每个像素为 1px尺寸,所以如果您围绕图像进行设计,您将需要px单位。它对于精确的字体大小和边框宽度也非常有用,由于四舍五入,它最适合使用px大多数屏幕的单位。

    所有绝对测量值都彼此严格相关;那是,1in is always 96px, 就像1in is always 72pt。 (注意1in实际上几乎从来都不是物理的inch当谈论基于屏幕的媒体时)。所有绝对测量均假定标称屏幕分辨率为 96ppi 以及桌面显示器的标称观看距离,并且在这样的屏幕上px将等于一physical屏幕上的像素和一个in将等于 96 个物理像素。在像素密度或观看距离显着不同的屏幕上,或者如果用户使用浏览器的缩放功能缩放页面,px将不再必然与物理像素相关。

  • em不是绝对单位 - 它是相对于当前选择的字体大小的单位。除非您通过使用绝对单位设置字体大小来覆盖字体样式(例如px or pt),这将受到用户浏览器或操作系统中字体选择的影响(如果他们已经制作了字体),因此使用 em 作为一般长度单位是没有意义的,除非您特别希望它缩放为字体大小秤。

    Use em当您特别希望某些内容的大小取决于当前字体大小时。

  • rem就好像em,但它是相对于文档(特别是根元素)的基本字体大小,而不是相对于当前元素的字体大小。

  • %也是一个相对单位,在这种情况下,相对于父元素的高度或宽度。它们是一个很好的替代品px如果您的设计不依赖于特定的像素大小来设置其大小,则表示设计的总宽度等单位。

    Using %设计中的单位允许您的设计适应屏幕/设备的宽度,而使用绝对单位,例如px才不是。

  • vh, vw, vmin, and vmax是相对单位,例如%,但它们是相对于viewport(窗口可视区域的大小)而不是父元素的大小。它们分别与视口的高度、宽度、两者中的较小者和两者中的较大者相关。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么是 em 而不是 px? 的相关文章

随机推荐

  • Laravel Eloquent ORM 中的自然 ORDER

    我如何在 Eloquent ORM 中获得 自然顺序 在表中我有 文本 列 字符串 正常顺序 Model orderBy text value 1 value 12 value 23 value 3 value 8 我需要这个 value
  • 运行 django 本地服务器时出错:`__init__() 得到意外的关键字参数 'tcp_nodelay'`

    一切都很好并且始终运行没有问题 现在 当我从浏览器加载应用程序时出现错误 似乎与代码无关 因为我跳到了最旧的分支上 并且得到了相同的错误 这是我的 python 和 django 版本 python version Python 3 6 0
  • 进行带有超时的 EJB 调用

    我有一个EJBA调用 EJBB UI 等待响应的时间不应超过 30 秒 如果某些数据丢失 它应该返回部分响应 如何在 EJB 上定义超时 30 秒的时间限制 B 我可以定义EJBB as Asynchronous返回Future 然后做Fu
  • 如何将嵌入/嵌套 FormGroup 转换为 FormData

    这是我的表格组 this shopGroup this fb group user name Validators compose Validators required Validators maxLength 60 url name d
  • C# - 文件关联对注册表项“HKEY_CLASSES_ROOT\”的访问被拒绝

    我目前有一个使用注册表设置文件关联的程序 注意 它是 NET 2 0 所以我必须通过注册表方法 问题是 由于它正在尝试写入 HKCR 因此可能会遇到管理问题 在其他计算机上 是否有更通用的方法来设置文件关联 对于 NET 2 0 例如使用
  • 无法将本地更改推送到现有远程分支

    有一个名为 my remote 的远程分支 我之前已毫无问题地推送到该分支 截至今天 我无法推动并且出现不同的错误 我得到的第一个错误是 hint Updates were rejected because a pushed branch
  • 无法文本对齐:CSS 居中

    我似乎无法将 主页 按钮置于中央 主文本位于左侧而不是中心 我的 htm 和 css 链接如下 html h1 Bully Free Zone h1 h2 Online harassment has an off line impact h
  • 打字稿 |每次调用函数时都会调用一个函数

    我正在尝试编写 Typescript API 服务 对于该服务 我需要一种方法来检查该方法是否存在 例如函数get叫做 我意识到我可以这样做 get endpoint string this handleRequest post endpo
  • 调整 UIWebView 文本大小

    我试图让用户调整给定网页的文本大小 我在 Xcode 6 中使用 Swift HTML 文件 h1 My First Heading h1 My first paragraph 这是我调用的快速函数来尝试更改大小 func changeWe
  • 如何使用Monitor(DDMS)工具调试应用程序

    这些天我正在将开发环境从 Eclipse 切换到 Android Studio 我真的很喜欢它的自动完成功能以及这个 IDE 提供的许多其他功能 但是 我在调试时遇到了一些问题 我希望使用这个IDE提供的Monitor工具 自带的DDMS和
  • 在单元测试中抑制 Vue 警告

    我试图按照此处列出的配置在测试中抑制警告 https vue test utils vuejs org api config html silent https vue test utils vuejs org api config htm
  • JavaFX 制作相同动画的副本

    我正在尝试扩展之前的作业 它是画一个风扇 并有一个滑块来控制播放速度 以及播放 暂停和反转风扇的按钮 这是我的该作业的代码 public class FanWithControls extends Application Override
  • 500 HTTP POST 请求的内部错误

    我正在使用下面的代码使用 HTTP POST 上传文件 但我从服务器收到 500 内部服务器错误响应 您能看一下并让我知道哪个代码部分是罪魁祸首 丢失的吗 HTTPS 连接没有错误 我认为标头存在问题 因此服务器不接受此请求 Check s
  • PHP/MYSQL AJAX 聊天

    寻找一个开源的php mysql ajax聊天室 不是1对1的私人聊天 你们会推荐什么 我将需要创建数百个聊天室实例 例如 每个用户组都有自己的专属聊天室 看看 phpFreeChat 这是一个易于实施的活跃项目 http www phpf
  • 如何在OpenAI中创建新的健身房环境?

    我的任务是制作一个 AI 代理 该代理将学习使用 ML 玩视频游戏 我想使用 OpenAI Gym 创建一个新环境 因为我不想使用现有环境 如何创建新的自定义环境 另外 我是否可以通过其他方式开始开发 AI 代理来玩特定的视频游戏 而无需
  • Django 1.0.2 中的多个数据库与自定义管理器

    我在用户组中询问了这个问题 但没有得到回应 所以我想我会在这里尝试一下 我正在尝试设置自定义管理器来连接到另一个数据库 在与我的默认 mysql 连接相同的服务器上 我努力了 遵循示例here http groups google com
  • 应用程序不使用 MSAL (react-aad-msal) 从缓存中获取访问令牌

    authProvider getAccessToken 为每个 API 调用调用身份验证端点 而不是从缓存中获取它 我不知道问题是否出在 Msal 中的 AcquireTokenSilent 或 React aad msal 中的 getA
  • 为什么静态块中的代码不执行?

    当我打印constant in main the static块不执行 但是当我打印时stat 它确实执行了 有什么重要意义吗static final在Java中 package com test doubt class Doubt pub
  • 如何编写包含“主体块”的自定义 WorkFlow 4 代码活动?

    这可能吗 我知道这是针对 MS 的 因为他们有 WF 活动包 但我不确定它是如何完成的 如果能够使用带有 Body 块的活动来插入其他活动 按钮等 那就太好了 如果不是太麻烦和 或耗时的话 如果您遵循一些规则 这很容易 以下是具有子项的 N
  • 为什么是 em 而不是 px?

    我听说你应该在样式表中定义尺寸和距离em而不是以像素为单位 所以问题是我为什么要使用em代替px在 CSS 中定义样式时 有一个很好的例子来说明这一点吗 说一个比另一个更好的选择是错误的 或者两者都不会在规范中给出自己的目的 甚至值得注意的