- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们的网络应用程序有一部分显示需要处理的可操作项目(“工作”)列表。我们的每个作业模型如下所示:
{
"JobUID": Number,
"State": "String",
"FirstName": "String",
"LastName": "String",
"DateOfBirth": "dateTime",
"DateReceived": "dateTime",
"LastWorked": "dateTime",
"UserName": "String",
"ProblemText": "String",
"AssignedTo": "String",
"DateAdded": "dateTime",
"CallOutStatusUID": Number,
"Notes": [
{
"NoteUID": Number,
"EntityUID": Number,
"Content": "String",
"UserName": "String",
"EntityTypeUID": Number,
"CreatedDateTime": "dateTime"
}
]
}
可以有0..n个注释
。我们通过 AJAX 为所有这些工作请求服务,并使用它们来填写表格。我们在这些作业进入的表上使用 jQuery TableSorter 插件。
最近,该列表已增长到其中的 735 个作业,总共有 907 个注释,fiddler 报告传输了 450 KB 的数据。该表与页面的起始选项卡位于不同的选项卡上。当您单击将显示此表的选项卡时,IE 会卡住。澄清一下,这些是 HTML 选项卡,全部位于 IE 内的一个页面上。它们不是多个 IE 选项卡。
当您尝试切换标签时,IE 的内存不会稳定增长(大约 98MB)。该进程处于 13% 的处理器使用率(在 8 核机器上,这告诉我它在单核上执行所有操作,因为 13% 是 ~1/8)。该进程永远不会再次开始响应,必须使用任务管理器关闭。当连接到 Visual Studio 2012 时,如果我尝试在这种情况下暂停和调试,VS 会报告它当前处于 native 代码中。我尝试在卡住之前设置一个 javascript 断点并进入卡住状态,但除了一些幕后的 jquery 调用之外,它似乎确实卡在 native 代码中。
我们暂时的快速解决方案是一次只显示 200 个职位并且它有效,但我们想要一种能够显示所有职位的方法。我开始使用 TableSorter 的 Pager 插件,但它没有帮助。排序器设置为每页仅显示 10 行。如果在尝试更改选项卡之前,我检查了该表中有多少行,它会成功报告 12(每页 10 行 + 1 个标题行 + 1 个过滤行)。
下面是我设置表格的方式(问题
是上述模型的数组):
for (var i = 0; i < problems.length; i++) {
var style = "odd";
if (i % 2) { style = "even"; }
var problem = problems[i];
rows += "<tr class='" + style + "'><td>";
rows += problem.FirstName;
rows += "</td><td>";
rows += problem.LastName;
rows += "</td><td>";
rows += problem.DateOfBirth
rows += "</td><td>";
rows += problem.ProblemText;
if (problem.CallOutStatusUID != null) {
rows += " - " + GetType(callOutStatus, problem.CallOutStatusUID).Display;
}
rows += "</td><td style='text-align:center;width:30px'>";
if (problem.Notes.length > 0) {
rows += "<a href='#' onclick='getNotes_click(this, \"JobUID\", GetJob, problems);' id='notes-" + problem.JobUID + "' JobUID='" + problem.JobUID + "' class='lnk_Notes'><img src='images/icon_note.png'></a>";
}
rows += "</td><td>";
if (problem.AssignedTo != null && problem.AssignedTo.toUpperCase() != userName.toUpperCase() && problem.State.toUpperCase() == "WORKING") {
rows += "<a href='imageviewer?JobUID=" + problem.JobUID + "'>Read Only</a>";
}
else {
rows += "<a href='imageviewer?JobUID=" + problem.JobUID + "'>Get Work</a>";
}
rows += "</td><td>";
rows += problem.LastWorked;
rows += "</td><td>";
rows += problem.AssignedTo;
rows += "</td><td>";
rows += problem.DateReceived;
rows += "</td></tr>";
}
$("#ListOfJobs tbody").html(rows).trigger('update');
奇怪的是,当在我们的开发环境(而不是我们发现问题的生产环境)中设置相同的场景时,我们可能有超过 1000 个作业,总注释超过 2000 个,并且它会正确显示。我试过在将大数组放入 DOM 后将其删除,但没有任何变化。我也试过删除 rows
但还是没有。还有多个其他选项卡,我可以在所有选项卡之间自由切换,页面似乎正常工作,直到我尝试打开包含此表的选项卡。更改浏览器不是一种选择。我什至无法在其他浏览器中进行测试,因为我们的 AJAX 调用在其中困惑,我们无法达到拥有所有数据并想要切换选项卡的这一点。我们不支持 IE<10。我们确实有一个运行 IE11 的开发人员,它也以完全相同的方式中断。
什么导致 IE 死机?
编辑:我尝试更改最后一行,这样它就不会调用触发器,现在选项卡加载得很好。有没有人对 TableSorter 有足够的了解,知道为什么这个触发器会出现这些问题?
编辑 2:我重新下载了 tablesorter 文件,结果发现我绝对没有使用最新的文件。当我切换到新版本时,一切正常。
最佳答案
Internet Explorer 不支持 innerHTML
对 <table>
的修改元素 [ citation ]
因此,jQuery 必须解析生成的大量 HTML 字符串并手动创建每个元素、设置属性、附加子节点、追加它们……除非他们添加代码以分离 <tbody>
在处理 DOM 之前,浏览器必须使用每个单独的操作重新计算整个表。
如果可能,请更改您的代码以便生成整个表格,并用它替换您之前拥有的任何表格。这将允许 jQuery 使用 innerHTML
,因为它使用浏览器的内部解析器,所以速度要快得多。
关于javascript - 防止IE卡住?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23619370/
我是网页设计新手。现在我遇到了我目前工作的 2 个网站的问题。我的模板只支持 Firefox 浏览器,不支持其他主流浏览器,如 IE、chrome、Opera、safari。 我试过一些 If IE
在我的 HTML 上,使用了下面的元标记来解决一些字体问题。我只想知道: 这两个元标记的含义相同吗?还是每一个都不一样? [以逗号分隔] [以分号分隔] 请解释一下。 最佳答案 Microsoft
这句话究竟是什么意思? 部分示例使用 ,分隔 IE 的版本,而有些使用 ; ;哪个是正确的? 订单IE=9; IE=8; IE=7; IE=EDGE有一些重要性,我想知道。 编辑:我正在使用 最佳答
这句话究竟是什么意思? 一些示例使用 ,分隔 IE 的版本,而有些使用 ; ;哪个是正确的? 订单IE=9; IE=8; IE=7; IE=EDGE有一定的重要性,我想知道。 编辑:我正在使用 最佳
在 IE 8 中,我们可以带出开发者工具。然后在顶部,有一个浏览器模式: IE 7 IE 8 IE 8 Compatibility View 所以如果 IE 7是强制页面显示为好像浏览器是 IE 7,
我认为不需要任何描述。我只需要我的 IE 11 单选按钮与 IE 8 中的一样,即颜色为 3-d 蓝色。在 IE 11 中,默认单选按钮是二维的,颜色为黑色。目前还没有解决这个问题。 最佳答案 检查这
我必须编写一个显示密码对话框的小程序。问题是对话框设置为始终在顶部,但是当用户单击 IE 窗口时,对话框仍然隐藏在 IE 窗口后面。并且由于对话框是模态的并且保持全部 IE 线程 IE Pane 不会
如何制作适用于所有 IE 浏览器的样式表。不只是 ie.css 中的 IE 8 本站主题的ie.css文件中只包含IE8样式。 最佳答案 他们这样做的原因是因为他们可能不支持 Internet Exp
使用有什么区别吗 ... 或者 ... ? 最佳答案 如果一种罕见的、神话般的浏览器被称为 ,就会有所不同。 Internet Explorer 6.66 被发现。 关于internet-explor
我试图在 IE7+8 中使用字体图标并遇到了一个问题,这个问题可以通过仅 IE7 的样式表轻松解决。长话短说,现在 IE7 和 IE9 都以某种方式运行我的仅 IE7 样式表(IE8 运行得很好)。我
我实现了上传的图片显示在网站上。为了 图片未正确上传意味着我将错误图片替换为 那?当我加载网站时,我遇到了 错误图像不存在的问题 定义,并且灯箱在 chrome 和 firefox 中加载 但它没有在
我有一个特殊的问题。我正在尝试“现代化”和为旧 IE 制作的旧应用程序,以便在 IE 11 中工作。但不知何故,CSS 类没有应用于 DOM 元素。 CSS 非常简单: .header { h
对于 IE 7 和 IE 8,IE 上 URL 的 2k 长度限制是否仍然存在? (后 IE 6 时代) 最佳答案 http://support.microsoft.com/kb/208427 似乎它
我们正在完善这个网站:dev.underglassframing.com 除了主要内容 div (#main) 后面的背景在 IE 7、8 和 9 中的内容之前停止外,在每个浏览器中一切都很好。我在末
我在 IE 11 中搜索过与 border-radius 相关的类似问题,但是 only one found on the Microsoft IE Developer site描述了自从“升级”到
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit th
这个问题在这里已经有了答案: (CSS?) Eliminating browser's 'selected' lines around a hyperlinked image? (5 个答案) 关闭
我知道有 1000 个问题,但我就是无法让它发挥作用。我只是想针对所有版本的 IE(包括 IE11)并给 html 一个特定的类,对于所有其他浏览器(firefox、opera、chrome),我希望
我有一个嵌入了 Internet Explorer 的程序。 在某些情况下,我需要调整嵌入式 IE 的缩放级别。我正在使用带有 OLECMDID_OPTICAL_ZOOM 的 ExecWB 命令来执行
我正在开发一个网络应用程序。我的应用程序在 chrome 和 firefox 上运行良好,但由于某种原因在 IE 中出现了一些错误。即使出现几个错误,应用程序仍然可以顺利运行,没有明显的问题。 我想对
我是一名优秀的程序员,十分优秀!