iPhone 4 Safari 上出现奇怪的水平空白

2024-01-09

在多个设备上测试我的网站的移动版本时,我注意到一个非常奇怪的行为。

我有一个可滚动内容 divoverflow: auto,并且这在所有测试的设备上都能正常工作,除了 Safari 上的 iPhone 4。其他浏览器和设备可以正确显示它,甚至 iPhone 5 Safari。

在 iPhone 4 Safari 上,当您滚动到内容末尾时,底部会出现大量额外的空白(看起来像是 100-200% 的额外高度),并且滚动时文本会消失。在 Safari 中的任何其他设备上都不会发生这种情况,在 iPhone 4 上的其他浏览器中也不会发生这种情况。

以前有人听说过这样的现象吗?我完全不知道是什么原因导致这种行为或如何解决它。

由于我只能访问有限数量的设备进行测试,因此我可能会忽略也发生此问题的其他设备/浏览器。如果您有移动设备并且也想测试它,实时站点在这里:现场直播 http://www.csleisure.com。在移动主页上,单击其中一个徽标以展开内容,然后尝试向下滚动。请在评论中发布您的结果。

  • 向下滚动时在 iPhone 5 Safari 上的显示效果(没问题):Image http://imageshack.us/a/img208/669/33gd.png
  • 向下滚动时在 iPhone 4 Safari 上的显示效果(问题):Image http://imageshack.us/a/img542/1792/0lxe.png

我斗胆猜测您在 Mobile Safari 中暴露了布局怪癖,因为您隐藏/显示每个内容的方式.company元素。每次您更改display元素的属性,浏览器必须执行回流。对于低功耗移动设备来说,回流焊(也称为布局)的费用高得令人望而却步。这可能可以解释为什么您只在 iPhone 4 上看到该问题。

我自己在 iPhone 4 和 iPhone 3GS 上进行了测试,两者都运行 iOS 6.1.3,只有当我展开顶部或底部时,我才能重现该问题.company元素,但不是中间元素。或许这是因为中间.company元素包含的子元素较少,这意味着需要较少的布局计算。

而不是申请display: block; and display: none;给里面的每一个孩子.company元素,我强烈建议您简化 JavaScript,以切换单个容器元素上的显示属性。通过这样做,您可以强制浏览器仅执行一次回流计算,而不是针对您单独更改显示属性的每个元素。

P.S.:iPhone 上的“其他”浏览器(即 Chrome 和 Opera)使用 UIWebviews。 UIWebviews 使用 Nitro Javascript 引擎的修改版本(Safari 版本启用了 JIT 编译)。这种细微的差异可能可以解释为什么该问题只能在 Safari 中重现。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

iPhone 4 Safari 上出现奇怪的水平空白 的相关文章

  • 在两个可移动 uiview 之间画线

    我有一个带有节点的 滚动视图 UIViews 可以拖动 我正在尝试在选定的之间绘制边缘UIViews使用 calayer 但我不知道当视图位置发生变化时如何重新绘制线条 In my viewControllerI 类在节点数组中添加第一个和
  • Twitter Bootstrap - 下拉菜单 - 箭头键不适用于 Firefox 中的输入标签

    要求 我想在带有用户名和密码字段的下拉菜单中放置一个登录表单 我可以做到这一点 除了以下问题之外 一切正常 Issue 打字时我无法使用箭头键 上 下 firefox 当输入位于下拉代码之外时 这很有效 这适用于其他浏览器 例如 googl
  • Div 独特的 CSS 样式链接

    我想为单个特定 div 中的链接创建独特的样式 例如 我希望主体中的所有链接为粗体和红色 但在侧边栏 div 中我希望它们为蓝色和斜体 我该怎么办 I have a link color 666666 a visited color 003
  • 如何将 SCNPlane 颜色更改为透明颜色

    我正在开发一个 ARKit 项目 在水平面上点击时需要波纹动画效果 为此 我采用了 UIView 对象并将其作为 SCNPlane 对象材料的内容传递 我已将波纹动画添加到 UIView 对象 一切正常 但我无法将 SCNPlane 颜色更
  • 增量后清除推送通知徽章

    我正在研究 iPhone 中的推送通知 当我收到推送通知时 它在我的应用程序图标上显示 1 下次显示 2 3 4 如果我打开应用程序 它是 0 下次它应该是 1 2 3 4 但它显示最后一个数字和 1 我想在打开应用程序后重置推送通知徽章
  • UIView 周围的虚线边框

    如何在周围添加虚线边框UIView 像这样的东西 如果您喜欢子层 还有另一种方法 在您的自定义视图的 init 中 输入以下内容 border 是 ivar border CAShapeLayer layer border strokeCo
  • 为什么我不能同时使用背景图像和颜色?

    我想做的是展示两者background color and background image 这样我的一半div将覆盖右侧的阴影背景图像 而左侧的另一部分将覆盖背景颜色 但是当我使用background image 颜色消失 完全可以使用颜
  • 移动设备上的 TensorFlow(Android、iOS、Windows Phone)

    我目前正在寻找不同的深度学习框架 特别是用于训练和部署卷积神经网络 要求是 它可以在带有 GPU 的普通 PC 上进行训练 但训练后的模型必须部署在三个主要的移动操作系统上 即 Android iOS 和 Windows Phone Ten
  • Xcode 服务器 ibtool 构建失败

    我一直在研究使用 Xcode Server 进行 CI 我已经解决了一些问题 但现在有一个问题困扰着我 构建似乎工作正常 但在测试阶段挂起 并在日志底部生成以下内容 2015 11 25 14 44 45 650 xcodebuild 58
  • 在“onClick”上切换 DIV 高度

    我想切换分区的高度 我尝试过将 animate 与 if else 语句一起使用 但它只会反弹 我现在使用的代码将隐藏我的分区而不是切换高度 点击时会触发 document ready function content1 toggle fu
  • Sphinx内联代码高亮

    我使用 Sphinx 制作一个包含代码示例的网站 我成功地使用了 code block获取语 法高亮的指令 但我无法使用此代码获得内联语法突出显示 role bash code language bash Test inline bash
  • admob ios7错误音频框架

    我正在将 admob SDK 当前的 集成到我的上一个应用程序 IOS7 Xcode5 中 并且出现了一个新错误 在新项目上也是如此 我想我错过了一些东西 但我多次重新启动该过程 但错误仍然存 在 Undefined symbols for
  • 在 Swift 中,如何为具有自动布局的 UIView 制作动画,就像页面滑入一样?

    我尝试创建一个 UIView 来表示一个大小与设备屏幕相同的页面 由于该应用程序支持方向 因此我使用 AutoLayout 来构建它 它工作正常 直到我尝试将页面动画化以从右侧滑入 经过一番研究后 我能想到的最好的办法是 myView UI
  • 如何将NSTextView的格式化内容转换为字符串

    我需要将 NSTextView 的内容从 Mac 应用程序传输到 iOS 应用程序 我使用 XML 作为传输文件格式 所以我需要将 NSTextView 的内容 文本 字体 颜色等 保存为字符串 有什么办法可以做到这一点吗 一种方法是存档
  • 播放循环声音的最简单方法是什么?

    在 iPhone 应用程序中播放循环声音的最简单方法是什么 可能最简单的解决方案是使用AVA音频播放器 http developer apple com library ios DOCUMENTATION AVFoundation Refe
  • 悬停时的 CSS 过渡

    我有个问题 实际上 当我将鼠标悬停在对象上时 我尝试在 div 上进行转换 所以基本上我有一个div 当我将鼠标悬停在div上时 它应该在其顶部显示另一个div 但是它应该被转换 这样悬停效果会更平滑 如果我有这两个 div 怎么可能 di
  • 伪元素的元素类型是什么?

  • AGVTool new-version 和 What-version 不对应

    当我做 agvtool new version all 99 它更新我的 Info plist 文件 但是 如果我这样做 agvtool what version or agvtool next version 我收到此错误 There d
  • 如何在没有 MFMessageComposeViewController 的情况下发送和接收短信?

    我想发送和接收短信而不显示MFMessageViewController从我的申请中 有人能告诉我这怎么可能吗 不可能 除非您使用第 3 方 api 发送 接收短信
  • 标题的下边框小于宽度

    我需要创建一个下划线效果底部边框小于h2标题的宽度 通常我不上传图片 但我认为这可能有助于进一步解释问题 您可以为此使用伪元素 例子 http jsfiddle net SZ39x pseudo border position relati

随机推荐

  • 如何在 AWS Route 53 中将流量从非 www 域名重定向到 www.example.com

    我在 AWS Route 53 中拥有一个域名 www derbyware com 我有一个 Web 应用程序运行在 http node147934 env 7029269 phx enscaled us http node147934 e
  • 如何运行独立的 Eclipse MAT?

    我使用 jmap 生成了 hprof sudo jdk bin jmap F dump file app hprof 5003 现在 我在 eclipse 中解析 hprof 时遇到 OOM Java Heap Space 错误 我想我需要
  • GLEW 链接问题找不到 __imp_glGetIntegerv

    注意 是的 我已经指定了 GLEW STATIC 因此 在尝试设置glew以在新项目中使用之前 我已经经历过这个牛仔竞技表演 但现在我在项目中使用glew 2 0 它产生了链接错误 我刚刚在 Linux 实例中生成了源代码并像这样使用它们
  • Celery + Redis - .get() 平稳运行约 70 小时后无限期挂起

    几天内一切都运行良好 但后来我无限期地挂在 get 上 发生无限期挂起所需的时间各不相同 但都在运行 24 到 72 小时之间 我怀疑这与Redis代理有关 的输出CLIENT LIST in redis cli显示大量连接且空闲数非常高
  • fullcalendar js 中未显示的事件

    请任何人帮我找出代码中出了什么问题 我使用 fullcalendar js 来处理日历事件 我想在日历中显示事件 下面是我的代码 document ready function window resize function calendar
  • 使用采样数据时CRC32函数如何工作?

    我想问你关于Python中以下短函数的解释 from zlib import crc32 def test set check identifier test ratio return crc32 np int64 identifier 0
  • Getline错误MFC vs2012(msvcp110.dll)

    我在使用 vs2012 中的 std getline 函数与 MFC 应用程序时遇到问题 同样的代码在vs2010中运行 这就是为什么我确信这不是代码本身的问题 void AddImage OnClickedIdbAiRegistratio
  • 具有自动完成功能的自定义交互式 Shell

    我的任务是创建一个嵌入到 python 中的交互式 shell 这样 当从命令行调用时 它将被放入该 shell 中 谁能给我推荐一个可以做到这一点的图书馆 我需要能够创建自定义单词 操作 以便当用户键入这些单词时 我的程序可以执行我创建的
  • 在 .js 文件中执行 PHP 代码

    我试图在 js 文件中执行一些 PHP 代码 但显然不知道如何正确执行 基本上 代码是向我的页面添加一些 HTML 标签 我将其用于滑出式联系表单 然而 联系表单本身是在 Wordpress 中通过短代码完成的 因此 我试图让短代码在使表单
  • 指定内容的构建操作 - Nuget

    告诉 Nuget 包将所有 css 文件添加为嵌入式资源 即构建操作是嵌入式资源 的最简单方法是什么 我试图通过工具文件夹中的 install ps1 来完成此操作 但仍然无法到达任何地方 注意 我正在从目录结构 tools content
  • switch case 编程练习

    enum SQLErrorCode OK 0 PARTIAL OK 1 SOMEWHAT OK 2 NOT OK 3 Code 1 int error getErrorCode if error SQLErrorCode PARTIAL O
  • 我可以通过 ssh 连接到 Windows,启动命令并让它在我注销时运行吗?

    现在 Windows 10 包含了 openSSH 服务器 是否有某种方法可以启动程序并让它在我注销时运行 在 Linux 上 有 screen 和 tmux 但是 Windows 上呢 Notes 能够重新附加到进程会很好 但这不是必需的
  • 当 list-marker 是伪元素时,list-style-position 不起作用。为什么?

    我想创建彩色列表标记 ul 我做到了 但现在在所有列表中list style position属性不起作用 这是代码 ul FirmStyle list style type none ul FirmStyle li before colo
  • asp.net正则表达式验证器客户端脚本错误

    我有以下正则表达式验证器来检测输入字符串是否包含 HTML 脚本标记 如果是则导致验证错误
  • Nodejs从哪里开始?

    我已经安装了nodejs并运行了几个简单的示例 例如在端口上打开服务器并侦听该端口 但是 我仍然无法将nodejs与web开发联系起来 所以为了学习和实现nodejs 我正在考虑使用rails和nodejs制作井字游戏 这可能吗 我正在设想
  • jQuery 可拖动自定义对齐网格

    我在项目中使用 jQuery UI Draggable 我有一个复选框可以切换可拖动对象上的网格 10x10 网格 选项 但是 当网格重新打开时 网格关闭时移动的对象不会与网格关闭时未移动的对象对齐 简而言之 这些对象位于不对齐的单独网格上
  • 自定义错误页面 .Net Core Web 应用程序未显示 500 错误

    我在生产中创建了一个自定义错误页面 它将要求用户更正 HTTP 状态代码页面 而不是显示丑陋的开发人员错误页面 我现在的代码如下 启动 cs public void Configure IApplicationBuilder app IHo
  • Bookshelf.js - 如何保存多对多关系?

    我在以 多对多 关系保存数据时遇到问题 这是我的模型 var CoursePeople bookshelf Model extend tableName course people var Course bookshelf Model ex
  • python subprocess - 分离进程

    我有一个 python 脚本af audit run py 它调用另一个Python脚本request audit py通过subprocess 第二个脚本request audit py在后台调用另一个子进程并返回请求 ID 问题出在第一
  • iPhone 4 Safari 上出现奇怪的水平空白

    在多个设备上测试我的网站的移动版本时 我注意到一个非常奇怪的行为 我有一个可滚动内容 divoverflow auto 并且这在所有测试的设备上都能正常工作 除了 Safari 上的 iPhone 4 其他浏览器和设备可以正确显示它 甚至