ios - 为什么简单的网站会在移动设备上崩溃(至少是 iOS Safari 和 Chrome)?

标签 ios google-chrome memory memory-leaks crash

我有一个非常简单但很长的网站——有很多可以滚动浏览的文本。这是一个文档站点,考虑到内容的性质(很多类似的简短条目),我决定一次显示所有内容,以便用户可以从一个条目滚动到另一个条目,或者通过侧边栏索引导航。这是我喜欢的常见文档模型(例如 UnderscoreBackboneLoDash )。

网站在这里:http://davidtheclark.github.io/scut/ .您可以在此处查看预生产代码:https://github.com/davidtheclark/scut/tree/master/docs/dev .

这就是问题所在:对于一些用户来说,这个网站总是让他们的 iOS 浏览器崩溃。不是所有用户(不是我);但对于那些确实经历过崩溃的人来说,它似乎一直在重复发生。 (该网站也可能会导致某些人的 Android 手机崩溃,我不知道:没有收到任何 Android 用户的消息。)我希望有人可以帮助我诊断并可能解决这个问题。 p>

我遇到的部分困难是我自己无法重现崩溃——不是在我自己的 iOS 设备上,也不是在 Xcode 模拟器上。因为该站点根本不占用大量资源(大约 70KB 负载)并且涉及的 JavaScript 很少,并且由于之前尝试解决此问题的一些影响,我猜测问题涉及内存使用 em> -- iOS 浏览器正在崩溃,因为该站点需要太多内存。但我不确定确定这是问题所在,如果是,我不确定如何解决。

我不确定接下来要尝试什么,我希望一些精明的 StackOverflow 高手能给点建议。这个网站在我看来如此简单和基本,是什么让它如此需要内存以致浏览器崩溃?

是不是太长了?是否存在难以渲染的 CSS?是否存在 JavaScript 内存泄漏?

我感兴趣既是为了这个特定的网站,也是为了学习在未来预测和预防和/或诊断和修复其他网站上的类似问题。

请随意查看或参与 [Github 问题](in this Github issue,以及。

附录

以下是有关该网站的一些相关信息:

  • HTML 文档相对于其他网站的 HTML 文档。未缩小的它看起来约为 225KB。 (我注意到 LoDash 文档更大——该网站会导致人们的手机崩溃吗?)
  • 提供的 HTML 文档已缩小。
  • 提供的 CSS 和 JS 也被缩小。
  • 网站使用Prism.js用于语法高亮。
  • 网站使用Overthrow使 2-scrolling-columns 布局适用于平板电脑。
  • <aside id="help-content">固定并在屏幕外翻译;当您单击 [?] 时,它会滑入,例如任何实用程序的“使用名”。

iOS 崩溃日志

在我看来,这些可能是来自运行 Chrome 并在网站上崩溃的 iPhone 的崩溃报告的潜在相关行(我不确定它们是否真的相关,因为我还没有开发 iOS 应用程序并且不知道'不知道这些报告的来龙去脉):

Free pages:                              5674
Active pages:                            117674
Inactive pages:                          55121
Speculative pages:                       3429
Throttled pages:                         0
Purgeable pages:                         0
Wired pages:                             60906
File-backed pages:                       23821
Anonymous pages:                         152403
Compressions:                            356216
Decompressions:                          121241
Compressor Size:                         16403
Uncompressed Pages in Compressor:        49228
Largest process:   Chrome

[...]

Chrome &lt;2a759438c2253e3baededaa0d13feb56&gt;       166479           166479  200  [per-process-limit] (frontmost) (resume)

最佳答案

我想我修好了!

怀疑是由 CSS 布局引起的渲染/绘画问题。在手机大小的情况下,我一直隐藏每个条目的内容,直到它被选中;以及我一直用来隐藏它们并从布局中删除它们的任何痕迹的方法,包括 position: absolute。我最初并没有使用 display: none ,因为出于各种读者和原因,我通常担心不想看到内容但将其保留在那里。我把这些顾虑放在一边,改变了布局,以便用 display: none 隐藏条目并用 display: block 显示——这似乎已经修复了崩溃。

我认为绝对定位是在屏幕一角堆积了大量的内容,虽然看不到,但对内存的要求很高。

让我尝试这个的线索是另一个相关问题的答案,由@tea_totaler 链接到上面:https://stackoverflow.com/a/14866503/2284669 .它说:

What tends to help me a lot is to keep anything that is not visible at this time under display: none. This might sound primitive but actually does the trick. It's a simple way to tell the renderer of the browser that you don't need this element at this time and therefore releases memory. This allows you to create mile long vertical scrollers with all sorts of 3d effects as long as you hide elements that you are not using at this time.

我认为我的另一种隐藏方法是释放内存,尽管它有其他优点(无论如何可能与这个特定站点无关)。我敢肯定,这只是因为网站太长了。

不过,当您想要隐藏元素时,需要考虑以下几点:渲染/内存需求

关于ios - 为什么简单的网站会在移动设备上崩溃(至少是 iOS Safari 和 Chrome)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20872344/

相关文章:

ios - 如何检索数组数据而不是字典?

javascript - Chrome 扩展在 flash 元素之上

html - Div 在 Internet Explorer 中工作,但在 Chrome 中不工作

bash - 如何从 URL 为 "localhost:3000"的终端打开 Google Chrome?

c# - 我要找回我的内存!我怎样才能真正处置一个控件?

ios - UIImage 内存未释放 VM : ImageIO_JPEG_DATA?

ios - Swift 4 只为一个 View Controller 设置导航属性

ios - 自动缩小后如何获取 UILabel 中文本的磅值

java - PriorityBlockingQueue 逻辑上无界但实际上并非如此?

ios - CRASH : [UIPageControl] Page out-of-bounds. 请求0但页面控件只有0页 : why?