10

自从在多部 iPhone 和 iPad 上升级到 iOS 7 后,我们看到我们网站上的部分 UI 发生了一些非常奇怪的事情。

所附图像中的粉红色框位于绝对定位的父级内,它有两个绝对定位在其中的白色 div,每个 div 具有不同的不透明度。粉红色的圆圈只是一个设置了边界半径以使其成为圆形的 div。此布局中根本没有图像。

出于某种原因,浏览器间歇性地拉伸粉红色的 div,但我想不出任何会导致它的东西 - 如果我想的话,我不知道如何实现这种效果!

我认为这是浏览器中的错误,但我不知道如何修复它。

我没有包含任何代码,因为它非常非常简单,并且没有任何东西会导致这种情况(实际上它在 iOS6 中有效)。只是希望有人以前见过这个?

有任何想法吗?

CSS问题

更新 响应 cimmamon 的评论,代码如下:

<div class="col" style="left: -3920px; width: 280px;">
<div class="periods">
    <div class="period3"></div>
    <div class="period2"></div>
    <div class="period1"></div>
    <div class="nodeline colBk">
        <div class="node colBrd"></div>
    </div>
</div>
<div class="inner">
    <div class="group first">
        <div class="branch colBk"></div>
        <a class="story">
            <div class="strip colBk"></div>
            <div class="caption">
                <div class="text">
                    <p class="title">Test</p>
                </div>
            </div>
        </a>
    </div>
</div>

以及适用于“句点”容器和子项的 CSS:

.tls .col { display: inline-block; position: absolute; top: 0; }
.periods { height: 72px; overflow:hidden; position: relative; border-left: 1px solid #fff; }
.period2 { height: 30px; opacity: 0.6; background-color: #fff; position: absolute; width: 100%; }
.period1 { height: 25px; opacity: 0.72; top: 30px; background-color: #fff; position: absolute; width: 100%; }
.nodeline { height: 61px; }
.colBk { background-color: #dd545c; }
.nodeline { height: 61px; }
.node { position: absolute; margin-left: -15px; left: 50%; bottom: 0px; width: 17px; height: 17px; border-radius: 50%; border: 6px solid #dd545c; background-color: #f9f9f9; }
.colBrd { border-color: #dd545c; }

这是一个奇怪的错误——我可以看到 CSS 中没有任何东西可以导致这种情况。

关于我可以添加哪些 CSS 可能会强制它正确呈现的任何建议?您会认为仅身高就足够了,但显然不是。

在这里提琴

4

4 回答 4

11

我遇到了这个问题,它现在也在 Safari 7 中。

这是我的案例的简化版本

HTML

<ul>
  <li>
    <a> Some text </a>
  </li>
  <li>
    <a> Some  other text </a>
  </li>
</ul>

然后我有一些javascript(在我的情况下是引导工具提示),它添加了一个元素,使html

<ul>
  <li>
    <a> Some text </a>
    <div style="position: absolute" class="tooltip"> Some content here </div>
  </li>
  <li>
    <a> Some  other text </a>
  </li>
</ul>

ul新 div会在整体被拉伸到新 div 顶部之前短暂显示。

这一定是 safari 中的一个错误,但是将以下 CSS 添加到插入的 div 可以作为一种解决方法。

.tooltip {
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
  transform: translateZ(0);
}

这会强制插入的 div 在一个新的复合层中呈现,这似乎可以防止 Safari 搞砸。

希望这足以让您找到解决方案,但如果没有,请告诉我,我可以进一步充实这个答案。

于 2013-10-23T11:18:19.097 回答
2

尝试使用backface-visibility

-webkit-backface-visibility:hidden;

它使我的方向伸展,一旦移开世界,过去和现在都是一个更快乐的地方

在 iOS 6 & iOS 7 & Android 4.2 + 上测试

于 2013-12-20T15:42:01.903 回答
1

另一个避免创建额外合成层的明显解决方法是添加perspective到 GPU 合成上下文中的元素。(在这种情况下,这是带有 的元素opacity。)请注意,如果您在 3D 空间中使用 定位物体translate3d,这将产生视觉影响,并且可能不是有效的解决方法。

.period1, .period2, .period3 {
  -webkit-perspective: 1px;
  perspective: 1px;
}
于 2013-11-11T18:47:07.767 回答
0

也许这可以解决问题:

添加高度:17px;到 .node 所以你的css应该看起来像

.node {
    background-color: #F9F9F9;
    border: 6px solid #DD545C;
    border-radius: 50% 50% 50% 50%;
    bottom: 0;
    height: 17px; /*new*/
    left: 50%;
    margin-left: -15px;
    position: absolute;
    width: 17px;
}

jsFiddle

于 2013-10-04T09:39:25.413 回答