当我们使用手机浏览器或微信浏览器打开Html网页的时候,如果上下滑动页面,页面就会出现黑色的空白(如图所示)。那么如何解决滑动的时候如何避免出界,出现头部和底部的黑底?
js代码:
var method ={
setScroll:function(isreturn,classname){//局部滚动添加样式local_scroll,回调
if(classname==undefined){
classname="local_scroll";
}
classname="."+classname;
var elm=document.querySelector(classname);
var isover=true;//用于判断回调是否执行一次
var overscroll = function(el,isreturn) {
if(el==null){
return;
}
el.addEventListener('touchstart', function() {
var top = el.scrollTop,totalScroll = el.scrollHeight,currentScroll = top+el.offsetHeight;
if(top === 0) {
el.scrollTop = 1;
}else if(currentScroll === totalScroll) {
el.scrollTop = top - 1;
}
if(isover && isreturn!=null){
isreturn();isover=false;
}
});
el.addEventListener('touchmove', function(evt) {
if(el.offsetHeight < el.scrollHeight){evt._isScroller = true;}
});
}
if(elm!=null){//取消body的滚动
document.body.addEventListener('touchmove', this.handler, false);
}
overscroll(elm,isreturn);
},
handler:function(){
if(!event._isScroller){
event.preventDefault();
}
},
};
html代码:
<style>
body,html{
margin: 0;padding: 0;height: 100%;
.local_scroll{//局部滚动
position:absolute; overflow:scroll; -webkit-overflow-scrolling: touch; top:0; left:0; bottom:0; right:0
}
::-webkit-scrollbar{//scroll滚动条设置
width: 0px; height: 0px;background-color: #fff;
}
}
</style>
<body>
<div class="local_scroll">
<!--这是内容-->
</div>
</body>
解决方法说明:通过移除body元素在屏幕上滑动的时候连续地触发的‘touchmove’事件,然后在body内部追加一层元素通过定位布局,同时监听屏幕上下滑动时间来实现,如果还有更简单的方法介绍的请留言或者私信我。