浏览器根据什么来判定脚本失控?[译]

作者:明达 来源:七月佑安 时间:2009-02-20 13:36:00 

在Web开发的时候,经常会遇到的一种情况就是浏览器提示脚本运行时间过长,停止还是继续,无论你选择什么,相信你都会想尽一切办法让这个对话框远离你的用户们。可你是否知道,这些不同的浏览器究竟是如何判断,哪些脚本处于“失控”状态么?本文作者,就从Internet Explorer、Firefox、Safari、Chrome和Opera五种浏览器,分析了这个情况出现的原因。

原文标题What determines that a script is long-running?
原文作者Nicholas C. Zakas

以下是对原文的翻译

Web开发者经常遇到并必须及时处理的问题就是“提示脚本运行时间过长的提示框”(或者称为“失控脚本提示”),这些令人讨厌的对话框会在你的脚本 执行时间过长的时候出现。对于Web开发者的基本准则就是,无论什么时候,都不要让用户看到这些对话框,因为这会给人一种代码缺乏结构化的印象,更简单的 说,你的代码负担太重了。

用Brendan Eich(JavaScript的发明人)的话来讲,如果JavaScript运行的时间需要用秒来计算,一定是什么地方搞错了。我个人可以忍受的上限可 能更小一些,不论什么脚本,在任何时间、任何浏览器上执行,都不应该超过100毫秒。如果实际执行的时间长于这个底限,一定要将进程分解成若干更小的代码 段。

另外,其实很少有人真正意识到究竟是什么原因导致脚本在不同的浏览器中运行时间过长,连我自己都没有深究过。所以我决定坐下来好好研究一下,我们究 竟会在什么情况才会看到那个讨厌的对话框。判断脚本是否失控,无外乎就两种方法。一种是根据执行了多少条语句,一种是判断脚本执行花费的时间。各个浏览器 判断脚本失控的具体方法会有略微的不同。

Internet Explorer

Internet Explorer判断一个脚本是否失控,主要通过JScript引擎执行语句的总数来判断。默认情况下,这个上限是500万条语句,这个值是可以通过注册表修改的。当你的脚本执行的语句数量超过这个限制,你就会看到下面的窗口。

这个对话框提示:“这个页面上有一段脚本导致Internet Explorer运行缓慢,如果你继续运行,你的计算机可能会变为无响应状态”。要不是追求技术上的准确性,这样说确实有点过了。对话框有两个选项,要么 停止脚本执行,要么允许脚本继续运行。当这个对话框显示的时候,脚本已经被完全停止了。如果你选择继续运行脚本,就会重新计算当前执行的语句数,也就是 说,如果这个数值再次达到上限时,你会再次看到这个对话框。

Firefox

Firefox是根据脚本引擎持续执行代码的时间来判断一段脚本是否失控。默认的上限是10秒,可以通过about:config页面来修改这个值。这里需要注意的是,当弹出类似alert的模式对话框的时候,是不计时的。当浏览器执行脚本的时间达到这个上限,Firefox就会显示类似下面的对话框:

Firefox的对话框提示:“这个页面的一段脚本目前运行忙,或者这段脚本已经停止响应。你可以停止执行这段脚本,并在调试器中打开这段脚本,或 者保持这段脚本继续运行”。更清楚的描述了遇到的问题,并且没有IE说的那么恐怖。在这个对话框上可以执行三种操作:停止脚本执行、调试脚本或者让脚本继 续运行。和Internet Explorer一样,当运行脚本继续运行以后,对持续运行脚本时间的统计就会重置。调试脚本按钮,只有在你安装了Firebug,并在该页面激活了调试 的时候才会出现。执行调试脚本操作后,可以显示执行时间过长的代码段的具体位置。

标签:浏览器,脚本,web,运行时间
0
投稿

猜你喜欢

  • 解决pyCharm中 module 调用失败的问题

    2022-11-27 23:21:19
  • MySQL 自动清理binlog日志的方法

    2024-01-17 11:37:59
  • Pytorch如何把Tensor转化成图像可视化

    2021-11-03 20:20:22
  • 最强Python可视化绘图库Plotly详解用法

    2022-03-08 11:01:07
  • 详解model.train()和model.eval()两种模式的原理与用法

    2021-03-20 08:46:56
  • Python实现扫描局域网活动ip(扫描在线电脑)

    2022-10-02 02:38:52
  • Django中的DateTimeField和DateField实现

    2021-02-03 20:38:13
  • SQL Server 压缩日志与减少SQL Server 文件大小的方法

    2024-01-22 04:26:45
  • MySQL数据库的授权原则

    2008-12-29 13:39:00
  • 5分钟教会你用Docker部署一个Python应用

    2023-11-12 10:24:09
  • VS Code配置Go语言开发环境的详细教程

    2024-05-11 09:08:31
  • NumPy之矩阵向量线性代数等操作示例

    2022-12-08 13:33:14
  • Pandas修改DataFrame列名的两种方法实例

    2021-09-30 06:26:16
  • 对python过滤器和lambda函数的用法详解

    2022-04-23 06:37:47
  • 利用Python破解斗地主残局详解

    2021-06-04 06:16:49
  • python中使用enumerate函数遍历元素实例

    2021-05-08 04:56:41
  • django框架中ajax的使用及避开CSRF 验证的方式详解

    2023-05-11 02:10:41
  • Pycharm虚拟环境创建并使用命令行指定库的版本进行安装

    2022-10-24 18:24:40
  • tensorflow 1.X迁移至tensorflow2 的代码写法

    2023-07-19 08:30:54
  • 关于数据处理包dplyr的函数用法总结

    2023-06-11 06:23:13
  • asp之家 网络编程 m.aspxhome.com