IFrame 在 IOS Safari 上不滚动

Jos*_*osh 1 html css iframe

当我使用 IOS Safari 时,网页上有一个 IFrame,但有一个错误,它不允许我向下滚动。我对此做了很多研究,发现这是一个常见的错误,但我似乎无法让我的版本正常工作。最具描述性的解决方案是 如何让 IFrame 在 iOS Safari 中响应?

尽管我无法让该方法为我工作。这是我到目前为止所拥有的:

索引.html

html,
body {
  padding: 0;
  margin: 0;
  border: 0;
}

iframe {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 0;
  border: 0;
  z-index: 9999;
  /* overflow: auto; */
}

#scroll-wrapper {
  -webkit-overflow-scrolling: touch!important;
  overflow-y: scroll;
  width: 100%;
  height: 150vh;
  z-index: 9999;
}
Run Code Online (Sandbox Code Playgroud)
<!DOCTYPE html>
<html>

<head>
  <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1">
</head>

<body>

  <!-- <div id="scroll-wrapper"> -->
  <iframe src="iframe.html" allowtransparency="true"></iframe>
  <!-- </div> -->

</body>

</html>
Run Code Online (Sandbox Code Playgroud)

iframe.html

html,
body {
  padding: 0;
  margin: 0;
  border: 0;
  width: 1px;
  min-width: 100%;
  *width: 100%;
}

div {
  display: block;
  margin: 0 auto;
  max-width: 300px;
  width: 100%;
  height: 1000px;
  border: 3px solid grey;
  text-align: center;
  line-height: 150px;
  margin-bottom: 50px;
  margin-top: 50px;
}
Run Code Online (Sandbox Code Playgroud)
<!DOCTYPE html>
<html>

<head>
  <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1">

</head>

<body>

  <div>Context1</div>

</body>

</html>
Run Code Online (Sandbox Code Playgroud)

zur*_*4ik 5

取消注释<div id="scroll-wrapper">并为 iframe 包装器添加此样式:

#scroll-wrapper {
    -webkit-overflow-scrolling: touch;
    overflow-y: scroll;
}
Run Code Online (Sandbox Code Playgroud)

请参阅大卫关于此技巧的帖子