当我们使用手机浏览器或微信浏览器打开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内部追加一层元素通过定位布局,同时监听屏幕上下滑动时间来实现,如果还有更简单的方法介绍的请留言或者私信我。
使用iframe(注意Iframe的高度默认150px,如果要改变iframe的高度,只能设置成具体的像素值,不能是百分比,使用window.open()直接打开外部窗口,在外部窗口中处理完成所有的操作后回到原来的页面,原来的页面出现一个确认是否完成操作的弹框。点击确认或者“cancel”之后接着调用其他的接口。
希望实现这样一个功能:点击一个链接,如果这个链接浏览器已经打开过,则刷新已经打开的链接窗口;如果这个链接没有打开过,则使用新窗口打开这个链接页面。这是一个非常好的体验增强功能
这篇文章主要介绍:js关闭当前页面(窗口)的实现方法。我需要在网页上创建一个按钮,用户点击:提示是否关闭浏览器(窗口),如果用户点击“是”,关闭该页面,如果“否”,则什么也不做。
过去CSS 有 4 个你必须知道的识别视窗口的单位,并且它们能够很好地处理每个可以想象的用例。然而,随着时间的推移和时代的变化,这 4 种视口单位现在不足以解决所有用例。
目前现代浏览器(支持最新ES标准)前端通信有PostMessage和Boradcast Channel两种消息机制。这里介绍Broadcast Channel API , 它可以实现同 源 下浏览器不同窗口、Tab 页、frame 或者 iframe 下的 浏览器上下文 (通常是同一个网站下不同的页面) 之间的简单通讯。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!