- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在开发一个应用程序,该应用程序比较不同浏览器中呈现的 DOM 以找出差异。我将其视为进行屏幕截图比较的替代方法。此外,这可以通过编程方式完成,误报更少(至少我是这么想的)。
我按照此处的建议通过 element.getBoundingClientRect() 计算元素的实际位置:retrieve the position x y of an html element .
我在 Firefox 和 Chrome 上尝试过,并从中生成了一个 JSON DOM 结构。现在我真的很困惑我得到了什么。我知道浏览器在子像素级别上处理像素值的方式不同,但它并不像 Chrome 总是有四舍五入的数字而 Firefox 总是有分数。它几乎总是这样:
火狐
{
"name": "SPAN",
"style": {
"display": "block",
"top": "1390.5",
"left": "824.61669921875",
"width": "123.38333129882812",
"height": "27"
}
}
Chrome
{
"name": "SPAN",
"style": {
"display": "block",
"top": "1390",
"left": "824.640625",
"width": "123.359375",
"height": "27"
}
}
chrome 中的 top 值始终是一个整数,而在 firefox 中它始终 是相同的值,但高出 .5 或 .25。
高度 比 chrome 高 1 或 0.5。
在这两种浏览器中,所有其他值有时都是分数。如果它们是分数,则它们永远不会相等(firefox 总是具有更高的值)。如果它们是整数,则它们是相同的。
我从来没想过会有这样的事情发生。特别是关于 top 和 height 值的奇怪之处。我会认为渲染只是不同,这会导致(不规则!!)不同的像素值。
所以我的问题是:如果我进行这种比较,是否可以从中得出任何规则?有谁知道firefox的舍入规则?或者我是否必须进行容忍 比较,检查值之间的距离是否超过 1 个单位?
更新:
如果您想自己快速检查一下,只需转至 http://example.com/ (因为它有一个非常小的 DOM)并在 firefox 和 chrome 的 javascript 控制台中输入 document.getElementsByTagName("body")[0].getBoundingClientRect()
。 Y、height 和 top 值在 firefox 中是非常长的浮点值,而在 chrome 中它们更短且奇怪地四舍五入。
最佳答案
ClientRect()的返回值是TextRectangle,看这里:https://developer.mozilla.org/en-US/docs/Mozilla/Tech/XPCOM/Reference/Interface/nsIDOMClientRect
所有坐标都是相对于视口(viewport)的,它的大小在不同的浏览器中是不同的。浏览器实际屏幕空间(视口(viewport)减去选项卡、工具栏、用户界面等)、子像素渲染的不同算法、字体渲染、内联 block 元素周围的空白大小(取决于默认字体大小)——这些都是影响视口(viewport)的因素尺寸,可能还有更多。更重要的是,这些因素经常随着每个新浏览器版本的不同而变化(加上用户可以更改设置),因此任何通过比较计算值得出的规则可能值(value)有限(如果有的话)。
至于处理子像素值,我建议始终使用 Math.floor 来防止任何不必要的布局破坏或调整设计以针对浏览器变化更加灵活。
关于html - DOM 元素在像素级别(宽度、高度...)的浏览器渲染差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27111584/
我从NVIDIA手册Eg中复制了以下代码:__threadfence()。他们为什么有 在以下代码中使用了__threadfence()。我认为使用__syncthreads()而不是__thread
我在使用 SVN 更改列表和 svn diff 时遇到了一些麻烦.特别是我想获取特定修订范围的特定文件列表的更改历史记录。 SVN 变更列表似乎是完美的解决方案,所以我的方法是: svn change
我有两个 IP 地址列表。我需要将它们合并到三个文件中,交集,仅来自 list1 的文件和仅来自 list2 的文件。 我可以用 awk/diff 或任何其他简单的 unix 命令来做到这一点吗?如何
假设自上次更新(恢复)到我的 a.b 文件以来我做了一些更改。 此 a.b 文件也在存储库中更改。 现在我想将我所做的更改与 repos 更改进行比较。 如果我 svn revert 文件,我可以看到
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我使用的是 openssl 1.0.1c , linux x86_64 我正在创建包含“hello”的文件(没有换行符) openssl dgst -sha256 hello_file i get :
假设我们有几个库。 有什么区别核心和 普通 图书馆?他们应该如何被认可,我们是否组织了两者的职责? +Common -Class1 +Core -Class2 +Lib1 has : Comm
如何在 SQLite 中计算以毫秒为单位的最小时间间隔? 好的,提供一些背景信息, 这是我的 table 的样子: link_budget table 所以有这个时间列,我想发出一个请求,以毫秒为单位
我想知道,乐观并发控制 (OCC) 和多版本并发控制 (MVCC) 之间的区别是什么? 到目前为止,我知道两者都是基于更新的版本检查。 在 OCC 中,我读到了没有获取读取访问锁的事务,仅适用于以后的
说到 SignalR,我有点菜鸟。刚刚开始四处探索和谷歌搜索它,我想知道是否有人可以向我解释完成的事情之间的一些差异。 在我见过的一些示例中,人们需要创建一个 Startup 类并定义 app.Map
我在 Ogre 工作,但这是一个一般的四元数问题。 我有一个对象,我最初对其应用旋转四元数 Q1。后来,我想让它看起来好像我最初通过不同的四元数 Q2 旋转了对象。 我如何计算四元数,该四元数将采用已
我了解 javascript 模块模式,但我使用两种类型的模块模式,并且想从架构 Angular 了解它们之间的区别。 // PATTERN ONE var module = (function()
我有两个具有完全相同键的 JSON。 val json1 = """{ 'name': 'Henry', 'age' : 26, 'activities' : {
我发现使用 VBA 在 Excel 中复制单个文件有两种不同的方法。一是文件复制: FileCopy (originalPath), (pathToCopyTo) 另一个是名称: Name (orig
我想知道查找两个 float 组之间差异的绝对值的最有效方法是什么? 是否是以下内容: private float absDifference(float[] vector1, float[] vec
我有一个关于 wicket getApplication 的问题。 getApplication() 和 getSession().getApplication 有什么区别? 部署 wicket 应用
我刚刚开始使用activemq,我有一个关于追溯消费者的问题,为了启用这个功能,你需要有一个持久的订阅。但是在主题上启用和不启用追溯的持久订阅有什么区别? activemq 文档说。 http://a
我有两个具有完全相同键的 JSON。 val json1 = """{ 'name': 'Henry', 'age' : 26, 'activities' : {
得到另一个 Erlang 二进制表示查询('因为这就是我最近正在阅读的内容,并且需要二进制协议(protocol)实现)。 如果我正确理解了类型说明符,那么对于“浮点”类型值,8 字节表示似乎很好(这
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
我是一名优秀的程序员,十分优秀!