浏览器什么时候开始渲染部分传输的 HTML?

2023-11-27

我有一个长期运行的报告,并希望在生成报告时向用户显示一个等待旋转器。我已经完成了这项工作,但不确定我是否以最好或正确的方式做这件事。

这是使用 ColdFusion,但我猜它可以是任何语言。在页面顶部,我有一些 Javascript (jQuery),它显示了一个等待旋转器,另外还有一个 documentReady 处理程序,我可以在其中将旋转器取下来。我刷新输出(如果重要的话),然后其余代码将处理报告内容。这并没有渲染旋转器,我推测,即使我正在服务器上刷新内容,但在此过程中发生了一些缓冲,并且浏览器永远不会看到旋转器代码,直到为时已晚。因此,我在刷新吐出几百行 HTML 注释之前添加了一个循环。微调行数后,就成功了。我当时认为其他网站也是这样做的。

但是:今天,在观看我的另一个页面逐行吐出长期运行作业的状态时,我突然想到该页面会在每行之后刷新,并且浏览器会根据需要增量呈现该页面。这与我上面的结论不符,现在我不知道规则是什么。有没有可预测的方法来做到这一点?每个浏览器都有不同吗?

澄清:我很欣赏尝试解释等待旋转器的正确方法的答案,但我只是使用等待旋转器作为示例来说明我真正的问题:是否有可靠的方法来预测浏览器何时开始渲染HTML 是通过网络传输给他们的吗?通过观察可以明显看出,浏览器不会等待 /html 标签开始工作。这个问题不一定与Javascript有任何关系。例如,我描述的显示状态的第二页是纯 HTML。


除了 Firefox 的内置延迟之外,还有其他区域会导致浏览器在渲染之前等待。

当 html 页面发送到浏览器时,它首先必须决定内容的去向,然后才能绘制屏幕。例如,表格因导致渲染延迟而臭名昭著。为了绘制表格,浏览器需要计算列大小。如果您使用百分比作为列宽或根本不指定它们,则浏览器必须在渲染之前获取整个表格。

但是,如果您使用类似的东西table-layout: fixed;css 属性,那么浏览器就可以读取第一行并在数据输入时开始绘制。

其他标签可能会导致类似的问题。基本上,每当浏览器必须计算内容的大小时,它就必须渲染所有内容。如果您可以通过使用固定大小(宽度/高度)元素提前给出提示,那么浏览器不需要计算出任何内容,并且可以在下载元素时绘制它们。

作为一条自我强加的规则,我从不让浏览器决定任何事情。相反,我给元素固定大小。因此,我工作的网站通常具有闪电般的快速渲染速度。

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

浏览器什么时候开始渲染部分传输的 HTML? 的相关文章

随机推荐

  • 实例化 Injectable 类时未调用 ngOnInit

    为什么不是ngOnInit 当Injectable类解决了吗 Code import Injectable OnInit from angular2 core import RestApiService RestRequest from r
  • WordPress 将“&&”更改为“&&”

    我正在使用PHPinclude 函数来包含静态PHP and JS我的 WordPress 页面中的内容 通过 ezPHP 插件实现 PHP 工作正常 但 JS 不行 我收到 非法字符 错误 每个实例 正在更改为 html 代码 我尝试将其
  • 如何判断您要从 WinForms 选项卡控件中移动到哪个选项卡?

    我需要确定用户在切换选项卡时来自和前往哪个选项卡 并可能取消切换 我尝试过取消选择 取消选择 选择 选定事件 所有这些事件都显示 e TabPageIndex 与 sender SelectedIndex 相同 是否有一个事件或属性可供我使
  • 类型擦除:Java 与 C# [重复]

    这个问题在这里已经有答案了 可能的重复 C 与 Java 泛型 Java use 类型擦除 while C 在运行时保留类型信息 该设计的语言行为有何实际差异 类型擦除存在很多问题 它勾起了不好的回忆 我从 1 6 开始就没有使用过 Jav
  • WebRTC的RTCDataChannel在iOS中的实现

    我在用ISBX apprtc ios视频聊天实现代码 这在 iPhone 和模拟器中完美运行 我想在两个对等点之间发送文本 字符串数据 并且我正在使用RTCDataChannel class 以下是我的实现 我无法建立连接 它总是给出状态k
  • 如何在不使用代码的情况下使用约束 AutoLayout 来指定横向与纵向的不同布局?

    我有一个带有登录屏幕的 iPad 应用程序 登录控件包含在 UIView 中 当 iPad 处于纵向方向时 我的登录 UIView 靠近应用程序的底部和中心 几乎就在键盘所在位置的正上方 公司徽标位于顶部居中的 UIImageView 中
  • ASP.NET MVC 4应用程序调用远程WebAPI

    我过去创建过几个 ASP NET MVC 应用程序 但以前从未使用过 WebAPI 我想知道如何创建一个简单的 MVC 4 应用程序 通过 WebAPI 而不是通过普通的 MVC 控制器来执行简单的 CRUD 操作 诀窍在于 WebAPI
  • Sharepoint API - 如何从 ASP.NET Web 应用程序将文件上传到 Sharepoint 文档库

    我是 Sharepoint Server 的新手 我们有任何实用程序可以从 ASP NET 应用程序上传文件吗 您能提供您宝贵的答案吗 您可以编写一些自定义代码来执行此操作 如果您位于同一服务器上或使用 Web 服务 则可以使用 Share
  • 是否可以转换参数包中的类型?

    是否可以转换参数包的类型并传递 例如 鉴于以下情况 template
  • 不存在具有键“xxx”的“IEnumerable”类型的 ViewData 项

    Stack Overflow 上有几篇关于此问题的帖子 但没有一个答案似乎可以解决我当前情况下的问题 我有一个页面 其中有一个表格 每行都有多个文本字段和一个下拉列表 所有下拉列表都需要使用相同的 SelectList 数据 因此我将其设置
  • 在共享主机上为 32 位 Linux 编译 git

    我需要在廉价的共享主机上设置 Git 客户端 并使用一个不知名的 32 位 Linux 发行版 GCC 不可用 所以我无法在服务器上编译它 我确实有两台其他 64 位 Linux 服务器和一台 OSX 笔记本电脑可供使用 我可以尝试在其上交
  • Gnuplot,如何*跳过*丢失的数据文件?

    根据各种因素 我可能没有 1 个或多个不存在的数据文件 在预定义的 gnuplot 绘图指令中引用 当这种情况我得到 警告 跳过不可读的文件 这会取消其余指令 有什么方法可以让 gnuplot 跳过任何丢失的数据文件并绘制所有现有的数据文件
  • 为什么我收到“错误:无法推送某些参考”?

    我有一个远程 git 存储库和一个我使用的本地存储库 每当我在本地进行任何更改时 我都会将它们推送到远程 然后我有时会在远程文件上执行 git commit 以存储远程文件上的更改 我根本不直接编辑远程存储库 我只是提交更改 我是一名单一开
  • Android堆碎片策略?

    我有一个 OpenGL Android 应用程序 它使用大量内存来设置复杂的场景 这显然会导致严重的堆碎片 即使不存在内存泄漏 也不可能在不因碎片而耗尽内存的情况下销毁和创建应用程序 碎片肯定是问题 而不是泄漏 这会导致一个主要问题 因为
  • python 3.x ImportError:没有名为“cStringIO”的模块

    我该如何解决ImportError No module named cStringIO 在Python 3 x下 来自 Python 3 0 变更日志 StringIO 和 cStringIO 模块消失了 相反 导入 io 模块并分别使用
  • 如何在嵌套 Backbone 集合上“冒泡”事件?

    我有一个 Backbone 应用程序使用嵌套集合 至少我认为他们是这样称呼的 在我的具体情况下有tabs and subtabs 每个选项卡 模型 包含子选项卡 模型 的集合 对于那些更熟悉代码的人 我将在下面写下我的模型和集合 以及子选项
  • 在 OS X Mavericks 中从 C++ 链接 C

    转换到 OS X Mavericks 和 XCode 5 0 1 后 我无法再将已编译的 C 文件 从 gcc 输出 正常链接到 C 项目 从 g 输出 从我的 makefile 生成的有问题的命令对是 gcc pkg config cfl
  • Bootstrap 3 像 Facebook 一样的 Canvas 侧边栏菜单

    我正在使用 Bootstrap 3 的一些示例作为移动设备上的画布外侧边栏菜单 如下所示 http jsfiddle net AllenDB 9aAjJ 我将如何调整画布外菜单 使其像 Facebook 的搜索 朋友在线画布外菜单一样 始终
  • 用于任意大数的 BCD 数学库?

    我正在寻找库存 Delphi Data FmtBcd 库的替代品 因为我刚刚达到了它的限制 例如它可以表示的最大十进制数字 并且程序以以下方式终止EBcd 溢出异常 出于好奇 我正在计算算术系列成员 并且需要处理非常大的数字 数十万个位置并
  • 浏览器什么时候开始渲染部分传输的 HTML?

    我有一个长期运行的报告 并希望在生成报告时向用户显示一个等待旋转器 我已经完成了这项工作 但不确定我是否以最好或正确的方式做这件事 这是使用 ColdFusion 但我猜它可以是任何语言 在页面顶部 我有一些 Javascript jQue