- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想知道使用包含大约 100 000 个元素(属性)的数组(或对象)是否会在浏览器中经常使用 indexOf、slice 等访问它们时导致性能或内存问题。是否有一些关于在中使用大数组的建议?现代浏览器?
我的特殊情况。我有以下结构:
tack01:[元素数组平均为 10 000]...tack0n: [平均10000个元素的数组]
跟踪平均数量为 10。
元素看起来像{id: "xa432fds", some properties}
在运行时,我需要访问任何知道提供它的 id 的元素。
如果我在不进行转换的情况下使用此结构,我需要在所有轨道中执行搜索并使用 indexOf 查找具有 Id 的元素。
所以我决定创建一个具有以下结构的索引对象:indexObj = {id1:对 id1 元素的引用,id2:对 id2 元素的引用}
要访问某个元素,我只需要访问 indexObj[id],这是适合我的情况的解决方案吗?
所有这些都应该在客户端执行。
最佳答案
这是一个非常宽泛的问题。
我想说的主要建议是真正深入地了解您正在使用的是什么。 JavaScript 中的数组 aren't really arrays at all ,它们是具有 JavaScript 普通对象的所有普通管道的对象。数组索引不是数字,也不是某些内存表中的偏移量*;它们是类似字典的映射中的字符串键。一旦您接受数组只是对象这一事实,它可能会开辟新的数据结构或访问方式,从而避免像 indexOf
这样的昂贵操作。
(* 当然,除了 JavaScript 引擎优化。引擎会优化。)
更新:查看您的编辑,是的,转换数据以便您可以使用它们的 id
作为属性名称(indexObj[ id]
) 是我推荐的。然后,您可以享受 JavaScript 引擎处理属性名称的好处,而不是 indexOf
所需的昂贵的线性搜索,这通常是更有效的查找(b 树和/或哈希结构)等)。
创建索引版本后,如果可以释放数组版本,则数组及其属性名称消耗的内存(“0”
,“1”
等)可以符合回收条件,这可能很有用(您的个人轨道将保留在内存中,因为您从索引结构中引用它们)。
关于javascript 大数组或对象 : browser performance and memory,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13309464/
在 Firefox 扩展的 Javascript 中,您可以调用 gBrowser.getBrowserForTab但是没有gBrowser.getTabForBrowser .所以我写了自己的并且它
在问这个可能含糊不清的问题之前,我搜索了 SO,发现许多对“现代浏览器”的引用,但没有定义。由于这是一个被广泛使用和引用的术语,令我惊讶的是我在 Internet 上找不到定义甚至描述。 那么,在 2
更新:老问题仅适用于 IE11 预览版;浏览器模式在 IE11 最终版本中回归。但有一个问题:它几乎没有用,因为它不模拟条件注释。例如,如果您使用它们在旧版 IE 中启用 HTML5 支持,您将无法再
我的移动页面和短信有问题:链接。该页面主要由基于 Android 和 iOS 的智能手机通过 QR 扫描应用程序访问。 特别是在 iPhone 上,有一些带有集成浏览器的 QR 应用程序(webkit
我想使用 CustomTabsIntent。但是我没有找到androidx的customTabs路径和版本。 最后我得到了这个:androidx.browser:browser:1.0.0 我想知道正
我想将来自不同域(支付提供商)的 ssl 安全页面加载到 iframe 中。据我所知,一些(或全部?)浏览器会在页面的某些部分受到保护而其他部分不安全时警告用户。 这是真的吗? 如果是这样,如果主站点
在 Protractor 中,有 browser.pause() function : Beta (unstable) pause function for debugging webdriver t
我可以使用以下方法检索浏览器日志 browser.manage().logs().get('browser').then(function(browserLog) { logger.info('
当使用 protractor 时,全局变量 browser 似乎具有 browser.driver 的所有功能。 我特地问这个是因为我不确定是使用 browser.wait 还是 browser.dr
面对 Protractor 的计时问题。有时我的 Protractor 测试用例会因网络或性能问题而失败。我已经解决了 browser.sleep() 的现有问题。后来知道了browser.wait(
我仍然无法找到解决此问题的方法。我们有一个启动浏览器窗口的应用程序,但我们使用的底层第三方插件尚不支持 IE9。我知道我可以通过点击 F12 并选择它来切换到 IE8 的浏览器模式。 有没有办法在命令
在 Protractor 脚本中,我总是遇到超时问题,即使我设置了很大的 time out jasmine interval、allscripttimeout...在某些地方,我不得不等到元素出现,比
我正在运行一个 Angular 应用程序,并且在 Protractor 上测试时尝试获取当前 URL。使用哪一个? browser.driver.getCurrentUrl() 或 browser.g
“所有浏览器兼容”和“跨浏览器兼容”有什么区别? “交叉”是什么意思,是指不同的操作系统吗? 如果任何网站在 IE 7、8 FF 3+、Safari 3+ 的桌面版本上运行良好,我们可以说它是跨浏
不明白浏览器同步中的错误阅读文档,其中 gulp 4 真的没有写任何关于它的内容。在 gulp 4 的文档中也没有理解(异步)。如何解决这个问题。谢谢。 bla bla bla bla bla bla
我正在尝试在 ASP.Net C# 代码隐藏中执行“如果浏览器是 IE 且版本低于 9”。 但是,在 chrome 中,以下行: if (Request.Browser.Browser == "IE"
我第一次玩 watir,使用 this site作为指导。我在一个简单的程序(如下)中遇到错误 - 它在第一个非要求行失败,如图所示。 如果我没有运行下面显示的内容,而是删除了该行,它会打开一个空的
下面的 if 条件我认为它是说 - 如果浏览器是 IE 并且 IE 浏览器版本高于 9,但我没有 IE 9 来测试它,所以很难知道正确的输出,这也是不是 100% 的我想要的 bcos 默认情况下该脚
我通过 Pingdom 测试了我的网站并得到了这个: 我进行了搜索,但找不到解决方案。有谁知道我怎样才能得到这个14到100? 最佳答案 不是一个完整的解决方案,但您可以通过将两个请求合并为一个来改善
是否可以禁用浏览器/窗口之间的 HTML5 拖放功能? 我正在使用具有 native HTML5 拖放功能的 Angular2 应用程序,并希望防止用户将其拖动到浏览器窗口之外并防止将可拖动对象拖放到
我是一名优秀的程序员,十分优秀!