2
因此,这里是我的问题:背后滚动位置:固定;在iOS
- 有一个弹出式菜单添加60像素高度的标题栏toggler
- 在页面上添加足够的内容来滚动当拨动弹出菜单 - 添加 溢出-Y:隐藏以html和/或正文和位置:固定为 弹出。
- 想法是,当我打开弹出菜单 - 我必须只 弹出可滚动区域,无法滚动背景 而弹出是开放
结果:
- 在iOS(iphone/ipad)背景上滚动,特别是当弹出到达滚动结束时。
- 如果我在标题栏上touchmove - 页面只在背景上滚动
- 弹出并不总是在滚动后到达视口的末端(主要在iOS上)。这个问题也部分出现在Android设备上。
- 动量效应使标题移动(不应该)。
下面是代码片段。
$('.dropdown-toggle').click(function(){
$('body').toggleClass('menu-dropdown-expanded');
})
body, ul {
margin: 0;
padding: 0;
}
.navbar {
height: 60px;
background: wheat;
}
.dropdown-window {
position: fixed;
top: 60px;
left: 0;
width: 100%;
height: calc(100% - 60px);
background-color: #e7e7e7;
display: none;
-webkit-overflow-scrolling: auto;
overflow-y: scroll;
}
.menu-dropdown-expanded {
overflow-y: hidden;
}
.menu-dropdown-expanded .dropdown-window {
display: block;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="navbar">
<ul class="main-menu">
<li>
<a href="#" class="dropdown-toggle">Dropdown toggle</a>
<div class="dropdown-window">
<ul>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
<li><a href="#">Some item</a></li>
</ul>
</div>
</li>
</ul>
</div>
<div class="my-content">
<p>Lorem ipsum dolor sit amet, vis viris inermis voluptatibus ad, ex ius elitr feugiat. Partem ignota temporibus ea vel, ius mentitum imperdiet in. Ius an clita ancillae placerat, sed graeci adolescens no. Utinam adolescens ullamcorper ea vix. Mel ipsum constituam te. Eu usu hendrerit eloquentiam, te case habeo porro vix.</p>
<p>Mea eu homero munere molestie. Sea facilisi signiferumque ea, mea an labore laboramus liberavisse. Sit ea nemore verear, nec posse populo virtute an. Ne pro nobis impetus. Nec cu vidit rebum augue. Aeque accommodare ne has. Ut vel graece persius bonorum, nam te inimicus persecuti, no pri dicta facilisis philosophia.</p>
<p>Errem accusata recusabo nec ne, at sed causae vivendo, possim detracto expetendis est id. Sit te mutat mazim dolorem, mel ei euripidis neglegentur. Usu eirmod integre minimum et, est mutat docendi delicata in. Qui nihil possit ei, cu nostrud eleifend liberavisse vim.</p>
<p>Ignota apeirian gloriatur at vel. Facete aliquid vulputate te duo, ea viderer placerat nec, est eu alienum posidonium dissentiet. Vis eu brute vocibus ponderum, animal omittantur usu cu. Wisi quas te per. Nec no vidit homero, saperet euripidis duo ut, at meis legendos maluisset per.</p>
<p>Simul iisque elaboraret ut pro. Minim euismod mei ei. Mei dolorem perpetua no. Quo viris admodum at. Ea vim harum apeirian delicata, ut sed interesset necessitatibus, copiosae petentium cu sit.</p>
<p>Nibh corpora invenire ne mea. Mei copiosae constituam te, te ius aeterno legendos pertinax, cu sed fugit hendrerit. Te quodsi comprehensam has, ea vel latine singulis consetetur. Est tation ancillae an, id vim quas vocibus. An mei amet quaeque evertitur, ridens apeirian ad eos. Ut nec minimum pertinax, eu vim veri lorem oportere.</p>
<p>Facer aliquam eos an, pri ex ipsum forensibus. No iusto dicit nam, ridens maluisset usu et. Sed detracto salutandi in, vis ex falli aliquip rationibus. Cu vim eirmod dolorem eligendi. His ea purto graece, feugiat forensibus vituperata ne est. Deleniti vulputate nam id, in labore euripidis omittantur nec.</p>
<p>Duo an regione phaedrum, mazim homero assueverit mel et. Illud adipisci cu his, et error invenire est. Invidunt efficiantur vis no, in vix mollis vocent, vitae debitis in his. Ne aperiri detracto molestie eam, illum euismod nonumes eos ei. Ea unum volutpat mediocritatem mei, eu nam novum oporteat eloquentiam. Quo ad iusto oporteat ocurreret.</p>
<p>Unum labores instructior quo ex, ius te diam viris reprehendunt. Eum debitis vocibus deterruisset eu. Ubique splendide repudiandae ex mea. Ex quo quem omnesque torquatos. Vim ea legere salutatus, at qui dolor sanctus habemus.</p>
<p>Tibique assueverit conclusionemque ut nec, quo illud gubergren ad. Mea commodo invenire ea, ius id oblique virtute constituto, his justo erant vidisse ut. Enim persius quo no, et pro ubique nonumes facilis. Ex vim malis deterruisset, eu diceret honestatis per, mea duis prompta molestiae no. Vim modus lobortis vulputate et, sit posse sententiae honestatis ea, duo cu detraxit reformidans. Et pro summo harum tritani, scripta accusam id mel, nam dicat iudico ex. Choro concludaturque id sed, has suas noster ne, ne aeque quidam mel.</p>
</div>
请注意,问题是不是由乳宁的代码上codepen可见。
我相信这可能被标记为重复,但经过一周的研究,我仍然没有找到任何解决方案。我不是最好的本地js,所以我更喜欢使用jQuery。
UPDATE:
截至Hieren feb's answer,我的所有问题都通过动量滚动的iOS是否存在等引起的。放置位置:弹出被激活时固定到身体修复问题。
加包装的div只是身体标记之后,并给它了:在菜单打开 – spankajd
隐藏@spankajd这不修复问题 – Onotoley
我面临同样的问题,并尝试了帮助我的同样的事情。 好吧也加上高度:100%溢出:隐藏,包装div。 – spankajd