React 项目:Safari 似乎正在渲染,但没有绘制元素?

erl*_*erl 2 safari rendering mobile-safari reactjs

我正在渲染一个卡片列表,每个卡片显示一些数据以及三行,允许用户导航到该卡片的特定扩展部分。

由于某种原因,Safari 似乎为每张卡片渲染了三个导航行,但它们是白色且透明的。我知道它们已被渲染,因为我仍然可以单击该行所在的空间并且导航按预期工作。它只是看不见的。

使用 Chrome 时不会出现此问题。它只发生在 Safari 上:无论是在浏览器中的桌面上还是在 iOS 上运行 Safari 时。控制台中没有错误。

另一个奇怪的难题是,当我在 Safari 中检查元素时,它们出现在屏幕上!这是我拍摄的展示该行为的视频的链接。

有任何想法吗???

erl*_*erl 5

为了防止有人偶然发现这一点,我采纳了 Jay 的建议并开始修剪 CSS。最终我意识到“更新行”同时设置了显示:“flex”和位置:“相对”。一旦我删除了position:“relative”,它一开始并没有做任何事情,但一定是错误添加的,Safari 完美地呈现了它。

TLDR:对于 Safari,在同一 div 上显示:“flex”和位置:“相对”会产生渲染问题。