- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我可以使用以下代码计算 selenium 中的页面加载时间:
代码:Selenium C#
using OpenQA.Selenium;
double requestStart = (long)((IJavaScriptExecutor)CTest.Driver).ExecuteScript("return window.performance.timing.requestStart");
double domComplete = (long)((IJavaScriptExecutor)CTest.Driver).ExecuteScript("return window.performance.timing.domComplete");
var totaltime = domComplete - requestStart;
通过试错,我能够确定上面代码中的totaltime对应于下图中的值Load。图像中的 Load 似乎总是与 DOMContentLoaded 变量的值相同。
问题:
以下文档很好地描述了每个时序变量测量的内容 mozilla-developer timestamp variables ,但 chrome devtools 中的 Finish 值正在搅浑水。
图:从 Chrome 的 Devtool (F12) 网络选项卡中提取性能信息
编辑:
感谢@wOxxOm。我注意到,随着我与网站交互(转到网站中的不同页面),完成时间不断增加,而 DOMContentLoaded 和 Load 从未改变在初始加载事件之后。这与您在回复中所说的相对应。我按照您的建议改用以下代码:
double connectStart = (long)((IJavaScriptExecutor)CTest.Driver).ExecuteScript("return window.performance.timing.connectStart");
double loadEventEnd = (long)((IJavaScriptExecutor)CTest.Driver).ExecuteScript("return window.performance.timing.loadEventEnd");
double newMeasure = (loadEventEnd - connectStart) / 1000.0;
还开始研究 Chrome 77 中的 LCP 功能。
我还有一个问题
问题 2:我最初认为 window.performance 对象中的值会在我单击链接(在网站上)时用新值(时间)重新填充,这会将我带到同一网站中的不同页面.但是,所有 window.performance 值在网站初始加载后都不会改变(在网站中移动时,Chrome 的 devtool 网络窗口中的 DOMContentLoaded 和 Load 值也不会改变)。
问题:为什么 window.performance 中的值从未改变?是因为这是一个 SPA(单页应用程序)吗?我观察了 chrome devtool 的 DOMContentLoaded 和 Load 在不同网站(较旧)中单击时的值,每次我转到该网站中的新页面时,DOMContentLoaded 和 加载 时间更改为显示网站内每个页面的加载时间(通过单击该网站主菜单中的链接转到不同的页面)。
最佳答案
DOMContentLoaded 表示所有 DOM 内容已加载,但 javascript 和图像仍在加载。
加载 表示加载所有内容,包括javascript 和图像。如果您在触发此事件 之前开始延迟加载图像和 javascript,它将延迟此事件并减慢您的页面加载事件。 这会对您的 google lighthouse 分数产生负面影响。
chrome 开发工具中的Finished 包括异步加载 Assets ,这可能会在触发 onload
事件后继续下载。一旦您的脚本之一开始通过 ajax 加载更多内容,完成时间就会增加。这个数字通常可以帮助您了解加载所有内容 需要多长时间,包括延迟加载的图像、脚本等。它可以而且应该在 load
事件之后加载,以改进您的 SEO 页面。
搜索引擎关注的真正重要事件是 load
事件。所以你并不真正关心 finish
时间。您希望在触发此事件后将与您的应用程序的第一次交互不需要的所有内容移动为延迟加载。
此外,您正在寻找 navigationStart
而不是 requestStart
。在用户按下回车键 (navigationStart) 和实际执行请求 (requestStart) 之间会有一些时间。
W3C 规范:
navigationStart
This attribute must return the time immediately after the user agent finishes prompting to unload the previous document. If there is no previous document, this attribute must return the time the current document is created.
MDN 引用
performance.timing.navigationStart + performance.now() will be approximately equal to Date.now()
触发 performance.now()
onload
告诉您到达那里需要多长时间。但是,IE9 不支持它,一些浏览器会舍入结果。使用 Date.now() - window.performance.timing.navigationStart
可提供更一致的结果并受 IE9 支持。
用于记录加载事件时间的 JS。
window.addEventListener('load', (event) => {
console.log('All assets are loaded')
console.log(Date.now() - window.performance.timing.navigationStart);
});
这与 SPA 页面有关。一旦加载了 DOM 和初始 Assets ,其他所有内容都将异步加载。 SPA 的路由在前端处理,不会触发 chrome 开发工具中的新页面加载。即使在手动重新加载页面时,您也必须禁用网络选项卡中的“保留日志”选项才能获得新的性能值。
关于javascript - 使用 Javascript 的 window.performance.timing 计算页面加载时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58054543/
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!