- 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/
在我早期的 R 生活中,当涉及到目录和子目录之间的分隔符时,我发现了 R 和 Windows 在不同页面上的痛苦。尽管我知道这个问题,但我仍然因为必须手动在所有反斜杠前面放置一个反斜杠或用正斜杠替换所
我正在尝试使用名为 easeInBounce 的缓动 jQuery 函数,但它不起作用。我搜索了所有相关内容,所有页面都说我必须像这里一样放置 {easing:'easeInBounce'} 但它不起
我不明白为什么使用 fgets 获取输入总是给我的程序“密码错误”。 但是,当我使用 gets() 时,比如 gets(array); 它起作用了。 预期输出:当密码错误时,打印“Wrong Pass
我刚刚给了this Hadoop tuorial在 JobTracker 中读取 Hadoop 有跟腱(单点故障)的状态: The JobTracker is a single point of fa
我有一个关于 csrf 缓解的问题。文献建议在每个页面上使用 token ,该 token 必须与任何表单一起提交 - 此 token 必须有效才能进行交易。 页面上的 token 如何防止 csrf
.NET 中是否有任何预先存在的方法来检测/防止 xpath 注入(inject)攻击? 我可以预见 2 个例子,但可能还有更多。 例如 "/Some/XPath/" + UntrustedNodeN
我已经在 http://jsfiddle.net/GxpSQ/ 上发布了一个代码有一个工作代码。单击该框,它将随机播放。 基于 hungred.com 我的代码基于此示例 http://hungred
我最近不得不迁移一个由负载均衡器和三个后端组成的基础架构。每个后端都设置了 apache2 来处理 HTTP/HTTPs 请求,并通过 AJP 协议(protocol)将它们转发到 tomcat 服务
系统的一个模块处理基于 JSON 的协议(protocol),该协议(protocol)用于传输各种数据。这导致了将近一百个小代码段,如下所示: /* * Data package Foo re
我希望有人能够帮助我理解这个问题,以及我是否需要采取任何额外步骤来保护我的应用程序。 阅读此特定漏洞,它似乎会影响符合以下条件的服务器: 从使用 HTTP 级压缩的服务器提供服务 在 HTTP 响应主
我希望能够在具有 REPR CStruct/CPointer 的类中使用双指针: typedef struct CipherContext { void *cipher;
我有一个X509Certificate2实例,并获取其PrivateKey属性,这是一个 RsaCryptoServiceProvider 。 MSDN 文档表明此 RsaCryptoServiceP
我们用于安全测试的第三方工具在 Tomcat 8 上存在慢速 HTTP POST 漏洞。我们在应用程序中有一个简单的 Spring Controller 和 JSP。 现有的 Tomcat 连接器配置
我已经设置了useHttpOnly=true在 tomcat context.xml 中,并且正在使用使用 java keytool 在 server.xml 连接器元素支持中生成的自签名证书来支持
根据 Azure 文档 github 问题 ( https://github.com/MicrosoftDocs/azure-docs/issues/75652 ) 中的 Azure 支持响应,Lin
我正在对我的 Java 代码执行 veracode 扫描,它在我的 DAO 类之一中引发以下错误 SQL 命令中使用的特殊元素的不正确中和(“SQL 注入(inject)”)CWE ID 89 但是,
我正在使用 Mongoose ODM wrapper对于 NodeJS,我担心注入(inject)攻击。假设我有以下架构: const UserSchema = new mongoose.Schema
我们有一个 jaxrs 服务,不幸的是执行了原始查询,没有准备好的语句。我们使用 ESAPI 来缓解 XSS、SQLI。如下所示: private String mitigateSQLI(String
我正在尝试减轻我们对 Poodle SSL 3.0 Fallback 的脆弱性攻击。我们的管理员已经开始禁用 SSL 以支持 TLS 用于与我们服务器的入站连接。我们还建议我们的团队在他们的网络浏览器
我在 Heroku 上有一个应用程序(免费计划),并且在从 Django 管理上传媒体文件时经常收到应用程序错误。我使用 S3 来提供静态和媒体服务。通过 django admin 直接将文件上传到
我是一名优秀的程序员,十分优秀!