- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个带有自定义下拉列表的菜单,其中可以包含数千个项目。这是最糟糕的情况,大多数时候是数百个或更少,而且速度都非常快。
我已将元素 (li) 的插入延迟到菜单打开时,但这会导致在打开菜单时单击它时出现几秒钟的明显延迟。
我在 javascript 中构建了一个包含所有列表项的字符串,并使用单个 innerHtml 赋值添加它。一直都是 innerHtml 赋值。我也尝试过使用片段并附加到片段以及使用片段并分别附加每个项目都无济于事。插入时间如下:
Text Li/InnerHTML Li/Inner/Fragment CreateLI/Fragment
Chrome 13ms 40ms 48ms 138ms
IE9 22ms 2402ms 2364ms 7934ms
IE11 19ms 1952ms 2330ms 4208ms
第一列是在单个 innerHTML 调用中插入所有内容,但只是插入 pre 标记内的文本和新行。不幸的是,样式和事件等需要 li。
第二列是在单个 innerHTML 调用中添加所有内容,但每个内容都包含在 li 标签中。
第三列如上,但使用片段然后附加它。
第四列如上,但每个 li 都作为单独的创建添加到片段中。
不幸的是,目标浏览器是 IE(我们将在圣诞节前后迁移到 IE11)- 公司内部网 :-(
我试图减轻这种情况的一件事是只插入第一个,比如 50 个项目。所以打开菜单很快,但在滚动时,我必须以 50 个为一组再次加载后续项目,直到滚动点。 IE 不够快,所以大多数时候您什么都看不到,并且在拖动滚动条时它会一直锁定、向前跳转、锁定等,因为在您尝试滚动时 innerHTML 调用会阻止整个浏览器。
我尝试过的另一种技术是插入前 50 个项目,然后以 50 毫秒的间隔加载剩余的 50 个 block ,以免阻塞所有内容。不幸的是,这会导致更糟糕的体验,因为页面响应会像上一个示例中滚动时那样断断续续,但在这里您甚至不必滚动,它总是滚动直到所有项目都被添加。
我现在没主意了。我怎样才能让 IE 运行得更快?
最佳答案
首先给出半评估的答案:(对您而言)最长为 8 秒。您可以做一个模态叠加层,显示加载动画 gif,在八秒内从 0% 计数到 100%。如果您愿意,我可以将您链接到一些在 HTML5 Canvas 中执行该动画的代码。这不是一个很好的解决方案,但它可以在页面加载时间过长时为您的用户提供一些东西。
可以说是更好的答案:按照您对自己的建议进行操作 - 加载前 50 个,然后滚动加载下一个 X 或每 X 毫秒加载一次(我更喜欢前者),然后编辑您的 CSS 和其他代码以确保页面不会像您在测试中遇到的那样以明智的方式做奇怪的事情。
最佳答案:你说是自定义菜单,其实就是菜单。因此,您应该缓存它而不是每次都重新加载它。每次在数据库中更改菜单时,您都会创建缓存文本文件。将文本文件加载到页面中几乎不需要时间,而且您使用的每种编程语言都可以做到。它的工作方式是创建一个函数来构建一个包含纯 HTML 菜单的 .txt 文件,然后在每次运行菜单更新函数时调用该函数(自然是在更新数据库之后)。
关于javascript - Internet Explorer DOM 插入速度的缓解技术,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20396831/
像其他人一样,我需要在 Internet Explorer 6 和 Internet Explorer 7 上测试我的代码。现在,Internet Explorer 8 为开发人员提供了一些很棒的工具
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicate: Running Internet Explorer 6, Internet Explorer 7, and Int
作为一名开发者,我发现新的 Internet Explorer 版本完全是一场噩梦。我关闭了 Windows 功能,但无法安装 Internet Explorer 10 。它说它已经安装,但事实并非如
我通过Blogger有一个博客-http://www.concertexperiencepeeps.com。每当我尝试通过Internet Explorer查看我的博客时,该页面都会崩溃,并且不允许我
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicate: Running Internet Explorer 6, Internet Explorer 7, and Int
我正在使用新的Internet Explorer 11开发人员工具将文档模式切换为“8”,但条件注释仍然被忽略,也就是说,它们没有被正确解析并且表现得像普通注释。因此,浏览器不会请求/加载条件注释内的
我在我的一个站点上遇到 Internet Explorer 6 问题,我真的希望我安装它而不是 Internet Explorer 7。有没有一种快速的方法来做到这一点? 最佳答案 下载Microso
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
如何访问 Internet Explorer 运行实例的经典 Internet Explorer COM 自动化对象?也就是说,如果我在多个窗口中打开 Internet Explorer,如何从 Po
string filename = Server.UrlPathEncode(Path.GetFileName(_Filename))); Response.AddHeader("Content-Di
当我尝试使用 Apache 2.2 在 Windows7(64 位)上的 IE9 或 IE10 中打开 localhost 时,解析 URL 需要很长时间。其他浏览器没有问题并立即解析 URL,只有
我有一个批处理文件,必须启动 Internet Explorer 并打开 www.google.com .当整个页面加载完成时,它应该终止 IE 进程,即关闭该系统中的所有 IE 实例。我的批处理文件
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6 个月前关闭。 Improve t
基本上,无论我使用 IE 访问哪个网站,我都可以看到那些黑色/白色形状,一旦我将鼠标移到它们上,它们就会消失。 想知道是否有人知道可能导致这种情况的原因? 另外:http://imageshack.c
我检查了所有注册表,但找不到所有已安装扩展的列表。 此时,IE 扩展/加载项的任何一般位置都会有所帮助。 最佳答案 取自 here : 浏览器帮助对象 - 旨在增强浏览器功能的浏览器插件。 条目可以在
我在Internet Explorer 8的LAN设置中使用了2个不同的自动配置脚本地址。在工作过程中,我需要经常在它们之间进行切换。每次我必须手动进行。 有没有一种方法可以通过脚本等自动执行操作,以
这是一个两部分的问题。我正在构建一个网页,我需要知道: 有没有办法检测 IE 是否启用了平滑滚动(如果是,如何)? 有没有办法强制 IE 关闭我网页的平滑滚动功能? 明确地说,我不是在问如何关闭整个计
我想强制 IE10 在 IE9 模式下从我的 Intranet 呈现某些站点。 我曾尝试使用本地兼容性列表但无济于事(%LocalAppData%\Microsoft\Internet Explore
我在使用 IE8 时遇到问题,其中带有查询字符串的 URL 在下载时被破坏。 特别是,像这样的 URL http://domain.com/software/Software%202.1%20Beta
我有一个非常基本的页面,其中包括 元素。当我提交带有选定文件的表单时,服务器会响应一个在 Excel 中打开的电子表格(“新窗口”)。这种行为意味着初始屏幕和输入元素在 IE 中仍然可见。如果我更改所
我是一名优秀的程序员,十分优秀!