javascript - 如果在移动设备上触摸滚动组件之外的区域,则滚动会在弹出窗口中卡住

标签 javascript html css mobile scroll

我有一个包含 2 个可滚动列表的页面:一个在正文中,第二个在弹出窗口中。当用户滚动弹出窗口中的内容时,我使用标准解决方案来防止正文滚动(我使用的解决方案在此处描述 Prevent BODY from scrolling when a modal is opened )

我在移动设备上使用此解决方案时遇到问题(我在 iPhone 6 上的 Safari 中对其进行了测试)。

我的问题如下:如果用户触摸弹出窗口之外的区域,他将无法在弹出窗口内滚动列表几秒钟。弹出窗口内的滚动条似乎在一段时间内卡住或不可用。

我在页面上使用了以下代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Title</title>

<style>

    html {
        height: 100%;
        width: 100%;
        overflow: hidden;
        min-width: 100%;
        min-height: 100%;
    }

    body {
        font-family: '.SFNSDisplay-Regular', -apple-system, Helvetica, Arial, sans-serif;
        height: 100%;
        width: 100%;
        padding: 0;
        margin: 0;
        font-size: 14px;
        background-color: gray;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
        overflow: hidden;

    }

    .main-container {
        border: 1px solid red;
        margin: 20px;
    }

    .block {
        border: 1px solid green;
        height: 100px;
        margin: 20px;
    }

    .btn {
        margin: 20px;
        border: 1px solid blue;
    }

    .hidden {
        display: none;
    }

    .popup-container {
        position: fixed;
        overflow: scroll;
        width: 100vw;
        height: 100vh;
        top: 0px;
        left: 0px;
        z-index: 20;
        background-color: rgba(0, 0, 0, 0.5);
    }

    .popup-content {
        background-color: white;
        width: 50vw;
        height: 500px;
        margin: 100px auto 0;
        overflow-y: scroll;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }

    #container {
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch;
        height: 100%;
    }

    #container.fixed {
        overflow-y: hidden;;
        position: fixed;
        border: 1px solid pink;
        -webkit-overflow-scrolling: auto;
        min-width: calc(100% - 60px);
    }

</style>

</head>
<body>

<div class="main-container hidden" id="container">
    <div class="block" onclick="showPopup()">1</div>
    <div class="block" onclick="showPopup()">2</div>
    <div class="block" onclick="showPopup()">3</div>
    <div class="block" onclick="showPopup()">4</div>
    <div class="block" onclick="showPopup()">5</div>
    <div class="block" onclick="showPopup()">6</div>
    <div class="block" onclick="showPopup()">7</div>
    <div class="block" onclick="showPopup()">8</div>
    <div class="block" onclick="showPopup()">9</div>
    <div class="block" onclick="showPopup()">10</div>
    <div class="block" onclick="showPopup()">11</div>
    <div class="block" onclick="showPopup()">12</div>
    <div class="block" onclick="showPopup()">13</div>
    <div class="block" onclick="showPopup()">14</div>
    <div class="block" onclick="showPopup()">15</div>
</div>

<div class="popup-container hidden">
    <div class="popup-content">
        <div class="header" onclick="showPopup()">Close popup</div>
        <div class="body">
            <div class="block">in popup 1</div>
            <div class="block">in popup 2</div>
            <div class="block">in popup 3</div>
            <div class="block">in popup 4</div>
            <div class="block">in popup 5</div>
            <div class="block">in popup 6</div>
            <div class="block">in popup 7</div>
            <div class="block">in popup 8</div>
            <div class="block">in popup 9</div>
        </div>
    </div>
</div>

<script
    src="https://code.jquery.com/jquery-3.1.1.js"
    integrity="sha256-16cdPddA6VdVInumRGo6IbivbERE8p7CQR3HzTBuELA="
    crossorigin="anonymous"></script>

<script>

var scrollhelper = {
    addFixedClassToContainer: function () {
        $('#container').addClass('fixed');
    },
    removeFixedClassToContainer: function () {
        $('#container').removeClass('fixed');
    }
};

function showPopup() {
    $('.popup-container').toggleClass('hidden');

    if ($('.popup-container').hasClass('hidden')) {
        scrollhelper.removeFixedClassToContainer();
    } else {
        scrollhelper.addFixedClassToContainer();
    }
}

$(document).ready(function () {
    $('#container').removeClass('hidden');
});
</script>

</body>
</html>

这是代码笔中代码的链接:http://codepen.io/annmirosh/pen/MJeaqO .

这是工作示例:https://sw22.firebaseapp.com

如果有任何解决滚动卡住问题的想法,我将不胜感激!

谢谢!

最佳答案

如果您的网站没有响应并且左右滚动,则会出现此问题,我的意思是说,如果您的网页在底部滚动,则会出现此问题。

但是,如果 HTML 部分的主体具有 overflow:hidden 的 css,则它不会滚动。 http://codepen.io/annmirosh/debug/MJeaqO 此链接无效。

此外,我已经检查了我自己的网站是否有模态弹出窗口也是否在右侧滚动不是没有触及任何其他空间。

如果用户触摸弹出窗口之外的区域(如果溢出主体上有 css 隐藏用户将永远不会获得弹出窗口之外的区域,因为弹出窗口的后层获得绝对定位或或随着 z 的增加而固定-index css 属性)。

这是正确的解决方案:http://stackoverflow.com/questions/9538868/prevent-body-from-scrolling-when-a-modal-is-opened

关于javascript - 如果在移动设备上触摸滚动组件之外的区域,则滚动会在弹出窗口中卡住,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41629418/

相关文章:

javascript - 单击标签时单选按钮不检查

twitter-bootstrap - 使 PNG 标志变大

html - <col 类 ="a specified background color"> 已忽略

JavaScript 函数无法在 Chrome 和 IE 上运行,但可以在 FireFox 上运行

javascript - 如何使用javascript获取元素的高度,包括填充和边框

html - 使用 flex(多个元素)进行垂直和水平居中

html - 您对 Internet Explorer 支持持什么立场?

javascript - 从 iframe 将 div 弹出窗口居中

javascript - 使用 chrome 扩展检查 javascript 库是否存在

javascript - 如何捕获多个功能的拒绝?