- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在我的 HTML 中我有一个 <div>
(称之为面板)具有包含一些文本的固定宽度;该文本设置为 font-size: 25px; line-height: 25px;
在随附的 CSS 中。碰巧文本以 36 行结尾。
鉴于所有边距、填充和边框均为零,您期望面板的高度为 36 * 25px = 900px
,这实际上就是我在 Firefox 中使用 DOM 的 getBoundingClientRect()
找到的内容方法。
但是,在谷歌浏览器中我得到不同的数字;看起来面板只有 892.7999877929688px 高而线是 24.799999660915798px 高。将这两个数字相除仍然是 36。看起来 CSS 中设置的标称像素与 getBoundingClientRect()
报告的实际像素之间存在缩放比例;在我的例子中,这是每真实像素 1.0080645299120465 标称值。
另一个证据来自在 nwjs 应用程序中运行的 Chromium,我最初在该应用程序中观察到差异。在我的测试中,它始终显示出与 Chrome 中的不同比率。现在,在我测试的某个时候,Chromium 报告的像素突然跳到 Firefox 报告的整数值;我不确定我做了什么来实现这一点。
可以预料,分数比率在某种程度上与页面缩放有关;毕竟,在非常小的尺寸下,Chrome 和 Chromium 会重排文本(有时会做错)。事实上,改变 Chrome 中的缩放比例会导致不同的比例,让 Chrome 放大到最大将使比例保持在 1。不过,我的 Chromium 应用程序没有放大到最大并且仍然有
一个小数ratio.
在测试中为整数像素比,但在实际应用中为分数值。
就我目前所知,我所能做的就是获得比率,以便我可以用 JavaScript 进行声音、一致的盒子尺寸测量,就是设置一个已知尺寸的盒子并测量它。
我仍然想知道观察到的行为的来源是什么。有这方面的报道吗?它是渲染器的有意行为还是突发行为?开发者讨论过吗?有获取比例的API吗?
我已经在 https://gist.github.com/loveencounterflow/d8c20b9021d2ab3f573a 的要点上放置了一些代码以简化测试。
最佳答案
某些字体无法以您要求的确切大小呈现,并且字体具有间接影响报告的实际大小的属性。如果你希望每个地方都有相同的行为,也许你必须导入你自己的字体来实现类似的渲染交叉浏览。我在使用 IE 和 Chrome 时遇到了类似的问题。
关于javascript - 为什么渲染像素与真实像素不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29035656/
我正在寻找x86 Assembly中pow(real, real)的实现。我也想了解算法的工作原理。 最佳答案 只需将其计算为2^(y*log2(x))即可。 有一个x86指令FYL2X计算y *
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
风格指南的最后一点 http://www.python.org/dev/peps/pep-0008 读... 不要使用 == 将 bool 值与 True 或 False 进行比较。 为什么? 编辑只
我似乎无法完成这件事。我仍然在我的日志中看到 cloudflare IP。目前,我有一个负载均衡器,它位于 Cloudflare 后面。 目前,这是与 forwardfor 相关的块: opt
此代码行选择任何类名不是“id”和“quantity”的 div 内的所有子输入:: $("div.item > div:not(.id,.quantity) > :input").live("key
我在测试真实产品时遇到错误。当我单击购买按钮时,出现错误“此版本的应用程序未配置为市场计费”。 我用这个例子https://github.com/robotmedia/AndroidBillingLi
到目前为止我能找到的所有答案都建议调用 omp_set_num_threads。虽然在大多数情况下这是一个正确的答案,但它对我不起作用。在内部,调用 omp_set_num_threads 会导致创建
假设我有 3 个显示器。如何仅通过其索引获取第二个句柄? EnumDisplayMonitors() 不会工作,因为它也枚举了伪设备,而 EnumDisplayDevices() 没有给我句柄。 最佳
我一直在尝试制作一个简单的小游戏来测试我的逻辑,这是一个简单的迷宫,它很丑,而且到目前为止很糟糕。 引擎工作得很好,考虑到迷宫已经存在(矩阵),它甚至可以愉快,但我无意绘制一堆 map ,这可能是在
Cloudflare 代理包含一个名为 CF-Connecting-IP 的 header 和用户的真实 IP。我想让 traefik 读取这个 header 并用它的内容创建一个 X-Real-Ip
我想要上下文菜单中的不同菜单项,具体取决于我在 JTable 中单击的行 大多数示例并没有真正显示上下文菜单(应该根据上下文 - 所选行进行填充) 我尝试过这个: popupMenu = ne
我有一个对象 callInst。如何获取函数的真实名称而不是 IR 代码中的名称?如果我在我的通行证中运行此代码(Useless 在另一个问题中发布) StringRef get_function_n
我在 Appium 和 iPad 2 上使用了以下所需的功能 DesiredCapabilities capabilities = new DesiredCapabilities(); capabil
根据documentation 我们可以通过以下方式在模拟器上运行我们的 android 项目: cordova 运行 android 或 cordova emulate android 但是如何在真
在 ASP.NET 中,有没有办法获得真正的原始 URL? 例如,如果用户浏览到“http://example.com/mypage.aspx/%2F”,我希望能够获得“http://example.
我的 NSInputStream 遇到问题。这是我的代码: case NSStreamEventHasBytesAvailable: printf("BYTE AVAILABLE\n"
$(selector).click() 结果没有任何反应。 this answer在浏览器控制台中工作,javascript 上下文设置为 iframe,但不是主页: simulateMouseCli
我在我的 AB Micro820 PLC 中设置了 modbus 映射。我在 40001 中有一个数组用于写入,在 42001 中有一个数组用于读取。两者都是 200 个元素和 REAL 类型(32
我正在寻找有关设计契约(Contract)管理数据模型的建议。因此,合约的一般生命周期是: 契约(Contract)已创建并处于“草稿”状态。它可以在内部查看,并且可以进行更改。 契约(Contrac
我正在尝试让我的 WebView fullscreen 达到标准,我知道如何将它拉伸(stretch)到“全屏”,但我想做的是当您长按 WebView 并选择全屏选项时,创建全屏。有谁知道该怎么做?
我是一名优秀的程序员,十分优秀!