H5解决浏览器,微信背景的上下滑动问题,脱离窗口的js局部滚动解决方法

时间: 2017-10-27阅读: 1427标签: 微信

当我们使用手机浏览器或微信浏览器打开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内部追加一层元素通过定位布局,同时监听屏幕上下滑动时间来实现,如果还有更简单的方法介绍的请留言或者私信我。

解决微信公众平台网页授权两次或多次重定响应问题

在做微信公众平台网页授权时,发现每次请求授权链接时都会重定向链接redirect_uri都会自动请求两次,由于并发导致了一些问题,那么,为什么会请求两次呢?,调试时发现会访问两次,一次是301,页面重定向了,第二次跟第一次就差这个参数connect_redirect=1

推荐几款常用的微信公众号排版工具

作为一个新媒体小编,我们常接触的几个工具,莫过于排版、素材、图片这几个了。今天天天主要是想给大家介绍几款我常用的微信排版工具,希望对大家有用。

微信分享朋友、朋友圈、QQ、QQ空间

先登录微信公众平台进入公众号设置的功能设置里填写JS接口域名,支持使用AMD/CMD标准加载方法,通过config接口注入权限验证配置,通过ready接口处理成功验证,通过error接口处理失败验证

微信JS支付代码 前端调用微信支付接口

跟大家分享一段微信支付的js代码片段、V3版的微信支付没有paySignKey参数、基本上是直接复制就可以使用了、改一改自己的参数就好了

用cookie解决新版微信中H5页面底部白条问题

实现思路是,引入cookie功能,创建一个存储访客微信用户信息的cookie。当用户首次访问时,通过oauth授权获取用户信息,并存储于cookie中。当用户再次访问时,判断是否有相应cookie来调取用户信息,这样就不会触发二次授权。

微信分享图标设置,以及wx.config配置

页面分享微信显示小图和描述的功能,微信就会抓取这张图片做为分享图片,微信对自定义分享内容作了限制,于是最终还是得回到配置wx.config上来。

js判断是否是微信浏览器方法总结【整理4种方式】

在实际开发中,我们需要知道当前的浏览器是微信内置的浏览器,那么如何判断呢?以下提示了四种方法,每一种都可以进行判断是否是微信浏览器。

H5禁止微信内置浏览器调整字体大小

微信webview内置了调整字体大小的功能,用户可以根据实际情况进行调节。但是这也会导致字体大小改变以后,出现页面布局错乱的情况。