当我使用 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)
取消注释<div id="scroll-wrapper">并为 iframe 包装器添加此样式:
#scroll-wrapper {
-webkit-overflow-scrolling: touch;
overflow-y: scroll;
}
Run Code Online (Sandbox Code Playgroud)
请参阅大卫关于此技巧的帖子