背景介绍:

开发企业微信的一个应用,实现在企业微信中调用自己程序页面,页面加载多模块数据,向下滑加载更多,等等等等,一波三折

然后很早就成功了是这样实现的:

html:

<div id="main-info">
<div class="listclean-header">
<label class="fontsize15 fontcolor333 ">
分店:</label>
<div id="selectbox" class="brancnlist">
</div>
</div>
<div class="listclean-body">
<ul id="cleanlist">
</ul>
</div>
<div class="listclean-footer">
<ul>
<li class="clean" value="">待打扫 </li>
<li class="clean" value="">已打扫 </li>
</ul>
</div>
</div>

js:异步获取数据

 ajaxdata: function (_branchid, _pageindex, _status) {//页面数据加载
var _this = this;
$.ajax({
url: "AjaxListClean",
type: "post",
data: { BranchID: _branchid, PageIndex: _pageindex, Status: _status },
aysnc: false,
success: function (res) {
$(".load-mask").hide();
$(".listclean-body").css("position", "static");
$("#PageIndex").val(res.PageIndex);
var _html = "";
for (var i = ; i < res.ListCleaning.length; i++) {
_html += "<li class=\"position-relative clean_" + res.ListCleaning[i].Status + "\" data-myid=\"" + res.ListCleaning[i].ID + "\">"
_html += " <p class=\"branch-name\">" + res.ListCleaning[i].Branch.Name + "</p>";
_html += "<p class=\"room-number\">" + res.ListCleaning[i].Room.Name + "</p>";
_html += "<p class=\"fontsize15\">" + res.ListCleaning[i].StatusString + "</p>";
_html += "<dl><dd>" + res.ListCleaning[i].TypeIDString[] + "</dd></dl></li>";
}
$("#cleanlist").append(_html);
$("#IsMore").val(res.IsMore);
$("#PageIndex").val(res.PageIndex);
$("#Status").val(res.Status);
$("#BranchID").val(res.BranchID);
if (res.PageIndex == "") {
_this.branchselectinit(res.ListBranch); //分店选择
}
listclean.goconfirm();
}
});
}

页面滚动的效果

getScrollTop: function () {//获取滚动条当前的位置
var scrollTop = ;
if (document.documentElement && document.documentElement.scrollTop) {
scrollTop = document.documentElement.scrollTop;
}
else if (document.body) {
scrollTop = document.body.scrollTop;
}
return scrollTop;
},
getClientHeight: function () {//获取当前可是范围的高度
var clientHeight = ;
if (document.body.clientHeight && document.documentElement.clientHeight) {
clientHeight = Math.min(document.body.clientHeight, document.documentElement.clientHeight);
}
else {
clientHeight = Math.max(document.body.clientHeight, document.documentElement.clientHeight);
}
return clientHeight;
},
getScrollHeight: function () {//获取文档完整的高度
return Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);
} window.onscroll = function () {
var _ismore = $("#IsMore").val();
if (_ismore == "") {//判断是否有更多数据
return false;
}
//页面中有一个头和一个底,然后前端姐姐告诉我
//第一次加载要加一个67px,才可以
var _pageindex = $("#PageIndex").val();
var _heightconfig = ;
if (_pageindex == "") {
_heightconfig = ;
} else {
_heightconfig = ;
}
if (listclean.getScrollTop() + listclean.getClientHeight() + _heightconfig == listclean.getScrollHeight()) {
$(".load-mask").show();//“更多”标志
$(".listclean-body").css("position", "fixed");
var _status = $("#Status").val();
var _branchid = $("#BranchID").val();
var _pageindex = $("#PageIndex").val();
//应该有一个效果
listclean.ajaxdata(_branchid, _pageindex, _status);
}
}

效果图:


然后第二个星期来了就不能用了,前端姐姐告诉我,她实现了一个右滑加载出半个页面展示个人信息!

这时候页面滚动监听时间就失效了

网上找原因:

1:html,body{height:100%;} 设置了100%的

2:position 和overflow 的问题;

解决方案:去掉height:100%,没啥用;

去掉了页面中最外部的div 的 postion:fixed;然后就好了!

但是,以前的计算方式是错误的,不能兼用不同手机设备!

改了一种算法:

js:

 window.onscroll = function () {
var clientHeight = document.documentElement.scrollTop === ? document.body.clientHeight : document.documentElement.clientHeight;
var scrollTop = document.documentElement.scrollTop === ? document.body.scrollTop : document.documentElement.scrollTop;
var scrollHeight = document.documentElement.scrollTop === ? document.body.scrollHeight : document.documentElement.scrollHeight;
if (clientHeight + scrollTop === scrollHeight) {//判断是否要去加载数据
$(".load-mask").show();
$(".listclean-body").css("position", "fixed");
var _status = $("#Status").val();
var _branchid = $("#BranchID").val();
var _pageindex = $("#PageIndex").val();
listclean.ajaxdata(_branchid, _pageindex, _status);
}
}

惊喜的发现,这是实现了类似于微信的数据加载,就是滑动到最上面加载更多数据,记下来吧,以后可能用到!

中间还去找了一个插件,可移植性比较差!

解决方案:修改js算法

js:

window.onscroll = function () {
var _ismore = $("#IsMore").val();//是否有更多数据
if (_ismore == "") {
return false;
}
var doc = document;
var win = window;
//滚动到底部距离
$ScrollBottom = $(doc).height() - $(win).height() - $(win).scrollTop();
if ($ScrollBottom == ) {
$(".load-mask").show();//更多标志
var _status = $("#Status").val();
var _branchid = $("#BranchID").val();
var _pageindex = $("#PageIndex").val();
//加载数据
listclean.ajaxdata(_branchid, _pageindex, _status);
}
}

这里去掉了$(".listclean-body").css("position", "fixed");这行代码,因为它会导致每次加载数据之后,页面自动滚动到最顶部!

//listclean-body数据主体的div

完美实现!


最后附上加载更多标志实现方式:

html+css:

<div class="load-mask">
<div class="load-bc">
<div class="load">
</div>
</div>
@charset "utf-8";
/* CSS Document */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
margin:;
padding:;
border:;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
display: block;
}
body {
line-height:;
}
ol,
ul {
list-style: none;
}
blockquote,
q {
quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing:;
}
body {
font-family: 'Lato', sans-serif; } .load-bc{width:80px;height:80px;border-radius:4px;background:Rgba(0,0,0,.8);position:absolute;top:40%;left:50%;margin-left:-40px;z-index:}
.load-mask{width:100%;height:100%;position:fixed;top:;left:;z-index:} .load{
margin: 35px auto;
font-size: 25px;
width: 10px;
height: 10px;
border-radius: 50%;
position: relative;
text-indent: -9999em;
-webkit-animation: load5 1.1s infinite ease;
animation: load5 1.1s infinite ease; }
@keyframes load5{
0%{
box-shadow: 0 -20px 0 0 #ffffff, 14px -14px 0 0 rgba(255, 255, 255, 0.2), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.2), 0 20px 0 0 rgba(255, 255, 255, 0.2), -14px 14px 0 0 rgba(255, 255, 255, 0.2), -20px 0 0 0 rgba(255, 255, 255, 0.5), -14px -14px 0 0 rgba(255, 255, 255, 0.7);
}
12.5%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.7), 14px -14px 0 0 rgba(255, 255, 255, 1), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.2), 0 20px 0 0 rgba(255, 255, 255, 0.2), -14px 14px 0 0 rgba(255, 255, 255, 0.2), -20px 0 0 0 rgba(255, 255, 255, 0.2), -14px -14px 0 0 rgba(255, 255, 255, 0.5);
}
25%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.5), 14px -14px 0 0 rgba(255, 255, 255, 0.7), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.2), 0 20px 0 0 rgba(255, 255, 255, 0.2), -14px 14px 0 0 rgba(255, 255, 255, 0.2), -20px 0 0 0 rgba(255, 255, 255, 0.2), -14px -14px 0 0 rgba(255, 255, 255, 0.2);
}
37.5%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.2), 14px -14px 0 0 rgba(255, 255, 255, 0.5), 20px 0 0 0 rgba(255, 255, 255, 0.7), 14px 14px 0 0 rgba(255, 255, 255, 1), 0 20px 0 0 rgba(255, 255, 255, 0.2), -14px 14px 0 0 rgba(255, 255, 255, 0.2), -20px 0 0 0 rgba(255, 255, 255, 0.2), -14px -14px 0 0 rgba(255, 255, 255, 0.2);
}
50%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.2), 14px -14px 0 0 rgba(255, 255, 255, 0.2), 20px 0 0 0 rgba(255, 255, 255, 0.5), 14px 14px 0 0 rgba(255, 255, 255, 0.7), 0 20px 0 0 rgba(255, 255, 255, 1), -14px 14px 0 0 rgba(255, 255, 255, 0.2), -20px 0 0 0 rgba(255, 255, 255, 0.2), -14px -14px 0 0 rgba(255, 255, 255, 0.2);
}
62.5%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.2), 14px -14px 0 0 rgba(255, 255, 255, 0.2), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.5), 0 20px 0 0 rgba(255, 255, 255, 0.7), -14px 14px 0 0 rgba(255, 255, 255, 1), -20px 0 0 0 rgba(255, 255, 255, 0.2), -14px -14px 0 0 rgba(255, 255, 255, 0.2);
}
75%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.2), 14px -14px 0 0 rgba(255, 255, 255, 0.2), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.2), 0 20px 0 0 rgba(255, 255, 255, 0.5), -14px 14px 0 0 rgba(255, 255, 255, 0.7), -20px 0 0 0 rgba(255, 255, 255, 1), -14px -14px 0 0 rgba(255, 255, 255, 0.2);
}
87.5%{
box-shadow: 0 -20px 0 0 rgba(255, 255, 255, 0.2), 14px -14px 0 0 rgba(255, 255, 255, 0.2), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.2), 0 20px 0 0 rgba(255, 255, 255, 0.2), -14px 14px 0 0 rgba(255, 255, 255, 0.5), -20px 0 0 0 rgba(255, 255, 255, 0.7), -14px -14px 0 0 rgba(255, 255, 255, 1);
}
100%{
box-shadow: 0 -20px 0 0 #ffffff, 14px -14px 0 0 rgba(255, 255, 255, 0.2), 20px 0 0 0 rgba(255, 255, 255, 0.2), 14px 14px 0 0 rgba(255, 255, 255, 0.2), 0 20px 0 0 rgba(255, 255, 255, 0.2), -14px 14px 0 0 rgba(255, 255, 255, 0.2), -20px 0 0 0 rgba(255, 255, 255, 0.5), -14px -14px 0 0 rgba(255, 255, 255, 0.7);
} }

移动端web页面上滑加载更多功能的更多相关文章

  1. vue 上滑加载更多

    移动端网页的上滑加载更多,其实就是滑动+分页的实现. <template> <div> <p class="footer-text">--{{f ...

  2. Android如何定制一个下拉刷新,上滑加载更多的容器

    前言 下拉刷新和上滑加载更多,是一种比较常用的列表数据交互方式. android提供了原生的下拉刷新容器 SwipeRefreshLayout,可惜样式不能定制. 于是打算自己实现一个专用的.但是下拉 ...

  3. Android 上拉加载更多功能

    前几天看了github上面的例子,参照它的实现,自己又稍微改了一点,往项目里面增加了一个上拉加载更多功能.具体的实现如下: 首先要重写ListView: import android.content. ...

  4. 移动端touch事件 || 上拉加载更多

    前言: 说多了都是泪,在进行项目开发时,在上拉加载更多实现分页效果的问题上,由于当时开发任务紧急,所以就百度找了各种移动端的上拉下拉 实现加载更多的插件.然后就留下了个坑:上拉加载的时候会由于用户错误 ...

  5. h5 实现页面上拉加载更多数据

    您好,您的上拉加载更多的代码来喽: html:(style部分:html部分:js部分--js部分主要就是监控上拉,调接口) //上拉加载更多css <style> .wait-loadi ...

  6. Android 开发 上拉加载更多功能实现

    实现思维 开始之前先废话几句,Android系统没有提供上拉加载的控件,只提供了下拉刷新的SwipeRefreshLayout控件.这个控件我们就不废话,无法实现上拉刷新的功能.现在我们说说上拉加载更 ...

  7. Android的ListView分页功能(上滑加载更多)

    今天主要工作是将之前实现的各种ListView显示全部信息,优化成了每次加载几条数据,然后上滑的时候加载更多,底部显示一个进度条和一个文字提示,然后加载完毕后,将提示信息隐藏. 一边看教学视频一遍敲代 ...

  8. 使用jquery.more.js上滑加载更多

    html: <div id="more"> <div class="single_item"> <div class=" ...

  9. Flutter移动电商实战 --(20)首页上拉加载更多功能的制作

    这节课学习一下上拉加载效果,其实现在上拉加载的插件有很多,但是还没有一个插件可以说完全一枝独秀,我也找了一个插件,这个插件的优点就是服务比较好,作者能及时回答大家的问题.我觉的选插件也是选人,人对了, ...

随机推荐

  1. Python处理验证码第一篇(pytesser初探及报错处理)

    (原文链接:http://blog.csdn.net/Bone_ACE/article/details/50436587) 前言: 春节期间,无法全身心投入地去写爬虫,那就玩玩验证码吧,应该比较有趣! ...

  2. js限制文本框只能输入数字方法

    输入大于0的正整数 <input onkeyup="if(this.value.length==1){this.value=this.value.replace(/[^1-9]/g,' ...

  3. Binary Tree Postorder Traversal --leetcode

    原题链接:https://oj.leetcode.com/problems/binary-tree-postorder-traversal/ 题目大意:后序遍历二叉树 解题思路:后序遍历二叉树的步骤: ...

  4. CCNA2.0笔记_路由分类

    直连路由:当在路由器上配置了接口的IP地址,并且接口状态为up的时候,路由表中就出现直连路由项 静态路由:静态路由是由管理员手工配置的,是单向的. 默认路由:当路由器在路由表中找不到目标网络的路由条目 ...

  5. Makefile 13——理解make的解析行为

    make是以从上到下的顺序读入Makefile中的内容的.然而,处理Makefile中的语句却并非完全从上到下. 大体上,make处理一个Makefile分为两个阶段.第一个阶段包含: 1.make读 ...

  6. love2d教程33--window模块

    --love的window模块比较简单,直接贴代码了function love.load() io.stdout:setvbuf("no") -- 设置io为无缓存模式 --获取显 ...

  7. vSphere Web Client使用指南之安装配置

    vSphere Web Client使用指南之安装配置 vSphere Web Client是为忙碌的管理员提供的一款通用的.基于浏览器的VMware管理工具,能够监控并管理VMware基础设施.在摆 ...

  8. linux—jdk 安装步骤

    1.         查看现有版本 java -version 2.         查看jdk的具体版本 rpm –qa| grep jdk rpm –qa| grep gcj 3.         ...

  9. CSS水平和垂直居中方案

    我们在网页布局的时候,经常会碰到需要居中的情况,那下面就来讲一下有哪几种目前比较常用的居中方案,它们的优点和缺点分别又是什么. 一.水平居中   方法①:(父元素)text-align,(子元素)in ...

  10. JSP页面之间传递参数的方法有哪些?

    JSP页面之间传递参数的方法有哪些? 解答: 1)request 2)session 3)application 4)提交表单 5)超链接