阻止移动设备上的用户无法水平滚动的最佳方法是什么?我试图有一个"滑出"菜单,打开时将身体内的所有内容推到一边。使用overflow: hidden
似乎没有影响。
目前,在移动分辨率(在iPhone / safari上进行测试)中,用户可以向右滚动,在点击"打开"之前显示菜单。按钮。因此,菜单不会对用户隐藏。
我无法在iPhone以外的其他移动设备上进行测试。
正在使用的元标记:
<meta name="viewport" content="width=device-width, initial-scale = 1.0, maximum-scale=1.0, user-scalable=no" />
指向实例的链接jsFiddle。
答案 0 :(得分:0)
支持溢出属性有时iffy是移动浏览器支持。因此,如果浏览器不支持overflow:hidden属性,用户仍然可以看到div。
我建议用display:none隐藏div,然后在脚本中,根据需要更改显示。
这是一个片段..
var body = $('body');
var button = $('#button');
var menu = $('#menu');
var menuWidth = $('#menu').width();
var closeMenu = $('#menuClose');
menu.css({
right: -menuWidth
});
button.html('Open');
function menuOperation() {
event.preventDefault();
if (body.css('right') == '0px') {
body.animate({
right: +menuWidth
}, 600);
button.html('Close');
button.css('background', 'rgba(203,203,203,1)');
menu.css('display', 'block'); /* added this */
} else {
body.animate({
right: 0
}, 600);
button.html('Open');
button.css('background', 'rgba(192,59,84,1)');
menu.css('display', 'none'); /*added this */
}
}
button.on('click', function(event) {
menuOperation();
});
closeMenu.on('click', function(event) {
menuOperation();
});
&#13;
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400,300,600);
body {
width: 100%;
right: 0;
margin: 0;
background: rgba(236, 236, 236, 1);
position: relative;
overflow: auto;
/*changed this */
}
#button {
width: 125px;
height: 30px;
padding: 10px 0 10px 0;
font-size: 20px;
background: rgba(192, 59, 84, 1);
color: rgba(255, 255, 255, 1);
font-family: 'Open Sans';
font-size: 20px;
text-align: center;
text-transform: uppercase;
position: absolute;
top: 15px;
right: 15px;
transition: all 0.2s ease-in-out;
-webkit-transition: all 0.2s ease-in-out;
-moz-transition: all 0.2s ease-in-out;
cursor: pointer;
}
@media(min-width: 321px) {
#button {
width: 100px;
height: 22px;
padding: 8px 0 10px 0;
font-size: 16px;
}
}
#menu {
width: 300px;
height: 650px;
background: rgba(24, 24, 24, 0.95);
color: rgba(255, 255, 255, 1);
position: absolute;
right: 0;
display: none;
/*changed this */
}
#menu > div:first-child {
width: 100%;
padding: 22.5px 0;
color: rgba(255, 255, 255, 1);
font-family: 'Open Sans';
font-size: 14px;
text-align: right;
text-transform: uppercase;
direction: rtl;
text-indent: 70px;
opacity: 1;
transition: opacity 0.8s ease-in-out;
-webkit-transition: opacity 0.8s ease-in-out;
-moz-transition: opacity 0.8s ease-in-out;
cursor: pointer;
display: block;
}
@media(min-width: 321px) {
#menu > div: first-child {
opacity: 0;
}
}
#menuClose {
width: 35px;
height: 35px;
border: 2px solid rgba(255, 255, 255, 0.15);
border-radius: 35px;
position: absolute;
top: 15px;
right: 15px;
cursor: pointer;
display: block;
}
#menuClose > span {
position: absolute;
top: 17.5px;
right: 0;
left: 7.5px;
}
#menuClose > span:first-child {
width: 20px;
height: 1.5px;
background: rgba(255, 255, 255, 1);
transform: rotate(45deg);
-webkit-transform: rotate(45deg);
-moz-transform: rotate(45deg);
display: block;
}
#menuClose > span:last-child {
width: 20px;
height: 1.5px;
background: rgba(255, 255, 255, 1);
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
-moz-transform: rotate(-45deg);
display: block;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div id="button"></div>
<div id="menu">
<div>Close Menu</div>
<div id="menuClose">
<span></span>
<span></span>
</div>
</div>
&#13;
还尝试将您的元标记更改为
<meta name="viewport" content="width=device-width, height=device-height">
希望这会有所帮助......
更新:: 在此处查看移动设备的浏览器兼容性部分https://developer.mozilla.org/en-US/docs/Web/CSS/overflow