前言

在我之前的项目中,页面总是干巴巴的,用户的体验不是特别完美,我也是一直觉得把设计师给到的psd做出来就好,很少考虑用户的感受。我喜欢看不同的App,操作每个步骤,观赏每个能和我互动的交互设计效果,我很喜欢。感觉有回应。

现在开始实现我页面的第一个交互效果,让我的页面更生动一点。

实现的插件

基于iScroll.js插件

代码

html

<div class="header">我是头部固定</div>

<div id="wrapper">

<div id="scroller">

<div id="pullDown"> <span class="pullDownLabel">下拉刷新</span> </div>

<ul id="thelist">

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

<li>我是小公举</li>

</ul>

<div id="pullUp"><span class="pullUpLabel">上拉加载更多</span></div>

</div>

</div>

<div class=""footer>我是底部固定</div>

css

*{margin:0;padding:0}

body{font-size:12px}

li{list-style:none}

.header{position:absolute;top:0;left:0;width:100%;height:45px;line-height:45px;text-align:center;color:#333;font-size:16px}

.footer{position:absolute;bottom:0;left:0;width:100%;height:45px;line-height:45px;text-align:center;color:#333;font-size:16px}

#wrapper{position:absolute;top:45px;left:0;bottom:48px;width:100%;}

#wrapper #scroller .thelist li{height:60px;padding:0 10px;line-height:60px;background:#ecf6ff;margin-top:10px;}

#pullDown,#pullUp{height:30px;line-height:30px;padding:0 10px;color:#888;text-align:center}

javascript

<script type="text/javascript" src="js/iscroll.js"></script>

<script>

var myScroll, pullDownEl, pullDownOffset, pullUpEl, pullUpOffset, generatedCount = 0;

function loaded(){

pullDownEl = document.getElementById('pullDown');

pullDownOffset = pullDownEl.offsetHeight;      //获取下拉刷新的div高度 30

pullUpEl = document.getElementById('pullUp');

pullUpOffset = pullUpEl.offsetHeight;               // 获取上拉加载的div高度 30

myScroll = new iScroll('wrapper',{

useTransition: true,                 //options.useTransition 默认为true,支持css transition 动画;

topOffset: pullDownOffset,     //通过topOffset参数属性设置iScroll已经滚动的基准值;

onRefresh: function(){             //通过onRefresh参数方法调整刷新后的界面结构

if(pullDownEl.className.match('loading')){

pullDownEl.className= '' ;

pullDownEl.querySelector('.pullDownLabel').innerHtml = '下拉刷新' ;

} else if (pullUpEl.className.match('loading')){

pullUpEl.className = '' ;

pullUpEl.querySelector('.pullUpLabel').innerHtml = '上拉加载更多' ;

}

},

onScrollMove: function(){                         //通过onScrollMove参数方法判断当前滚动是在顶端还是底端

if(this.y > 5 && !pullDownEl.className.match('flip')){

pullDownEl.className = 'flip' ;

pullDownEl.querySelector('.pullDownLabel').innerHtml = '刷新释放' ;

this.minScrollY = 0;

} else if(this.y < 5 && pullDownEl.className.match('flip')){

pullDownEl.className = ' ' ;

pullDownEl.querySelector('.pullDownLabel').innerHtml = 'Pull down to refresh...' ;

this.minScrollY = -pullDownOffset;

} else if (this.y < (this.maxScrollY - 5) && !pullUpEl.className.match(flip)){

pullUpEl.className = 'flip';

pullUpEl.querySelector('.pullUpLabel').innerHtml = '释放刷新';

this.maxScrollY = this.maxScrollY;

} else if (this.y > (this.maxScrollY + 5) && pullUpEl.className.match('flip')){

pullUpEl.className = ' ';

pullUpEl.querySelector('.pullUpLabel').innerHtml = 'Pull up to load more...;

this.maxScrollY = pullUpOffset;

}

},

onScrollEnd: function(){

if(pullDownEl.className.match('flip')){

pullDownEl.className = 'loading';

pullDownEl.querySelector('.pullDownLabel').innerHtml = '加载中';

pullDownAction();

} else if(pullUpEl.className.match('flip')){

pullUpEl.className = 'loading';

pullUpEl.querySelector('.pullUpLabel').innerHtml = '加载中';

pullUpAction();

}

},

});

loadAction();

};

document.addEventListener('touchmove',function(e){

e.preventDefaule();

},false);  //阻止冒泡

document.addEventListener('DOMContentLoaded',function(){

setTimeout(loaded,0)

}.false);   //当DOMContentLoaded 事件触发时,仅当DOM加载完成,不包括样式表,图片,flash。

//初始状态,加载数据

function loadAction(){

var el, li;

el = document.getElementById('thelist');

for(var i = 0; i < 10; i++){

li = doument.createElement('li');

li.innerHtml = '初始数据--' + (++generatedCount);

el.appendChild(li, el.childNodes[0]);

};

myScroll.refresh();

};

//下拉刷新当前数据

function pullDownAction(){

setTimeout(function(){

//这里执行刷新操作

myScroll.refresh();

},400);

};

//上拉加载更多数据

function pullUpAction(){

setTimeout(function() {

var el, li;

el = document.getElementById('thelist');

for(var i = 0; i < 10; i++){

li = doument.createElement('li');

li.innerText= '上拉加载--' + (++generatedCount);

el.appendChild(li, el.childNodes[0]);

};

myScroll.refresh();

},400);

}

//ajax

eg:  function pullUpAction(){

setTimeout(function(){

var el, li, i;

document.getElementById("thelist");

//========================

$.ajax({

type: "GET",

url: "LoadMore.aspx",

data: { page: generatedCount },

dataType: "json",

success: function(data){

var json = data;

$(json).each(function(){

li = document.createElement('li');

li.innerHtml = ' XXXXXXXXXXXX';

el.insetBefore(li, el.childNodes[0]);

})

}

});

//==========================

myScroll.refesh();

},1000);

}

</script>

参考搬运代码地址:http://blog.csdn.net/xw505501936/article/details/48975991

H5页面基于iScroll.js插件实现下拉刷新,上拉加载更多的更多相关文章

  1. SwipeRefreshLayout实现下拉刷新上滑加载

    1. 效果图 2.RefreshLayout.java package myapplication.com.myapplication; import android.content.Context; ...

  2. Android 下拉刷新上啦加载SmartRefreshLayout + RecyclerView

    在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/de ...

  3. juery下拉刷新,div加载更多元素并添加点击事件(二)

    buffer.append("<div class='col-xs-3 "+companyId+"' style='padding-left: 10px; padd ...

  4. 移动端下拉刷新上拉加载-mescroll.js插件

    最近无意间看到有这么一个上拉刷新下拉加载的插件 -- mescroll.js,个人感觉挺好用的,官网地址是:http://www.mescroll.com 然后我就看了一下文档,简单的写了一个小dem ...

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

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

  6. 基于SwiperJs的H5/移动端下拉刷新上拉加载更多的效果

    最早时,公司的H5项目中曾用过点击一个"加载更多"的DOM元素来实现分页的功能,后来又用过网上有人写的一个上拉加载更多的插件,那个插件是页面将要滚动到底部时就自动请求数据并插入到页 ...

  7. 基于SwiperJs的H5/移动端下拉刷新上拉加载更多

    最早时,公司的H5项目中曾用过点击一个"加载更多"的DOM元素来实现分页的功能,后来又用过网上有人写的一个上拉加载更多的插件,那个插件是页面将要滚动到底部时就自动请求数据并插入到页 ...

  8. JS+CSS实现的下拉刷新/上拉加载插件

    闲来无事,写了一个当下比较常见的下拉刷新/上拉加载的jquery插件,代码记录在这里,有兴趣将代码写成插件与npm包可以留言. 体验地址:http://owenliang.github.io/pull ...

  9. vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件

    vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件/库 一提到移动端的下拉刷新上拉翻页,你可能就会想到iScroll插件,没错iScroll是一个高性能,资源 ...

随机推荐

  1. [Vue warn]: Failed to mount component: template or render function not defined.解决方案

    命名视图 vue router 里有一个 模式叫做 命名视图 本来一个页面里面只能有一个路由视图 对应 一个组件,现在可以多个路由视图 对应 多个组件. 出错点 点击标签之后,<router-v ...

  2. ERROR 2059 (HY000): Authentication plugin 'caching_sha2_password' cannot be loaded: /usr/lib64/mysql/plugin/caching_sha2_password.so: cannot open shared object file: No such file or directory

    部署docker下的mysql时出现以下报错 [root@docker ~]# mysql -h192.168.30.22 -uroot -p Enter password: 出现报错: ERROR ...

  3. 【Java_基础】并发、并行、同步、异步、多线程的区别

    1. 并发:位于同一个处理器上的多个已开启未完成的线程,在任意一时刻系统调度只能让一个线程获得CPU资源运行,虽然这种调度机制有多种形式(大多数是以时间片轮巡为主).但无论如何,都是通过不断切换需要运 ...

  4. GIMP素描效果

    1/打开图片,拖动图片到GIMP软件 2/复制两次图层 3/选中最上面的一个图层,mode改为Dodge 4/点击Color,选择Invert,可以看到图片变淡了 5/点击Filters,Distor ...

  5. 记我的小网站发现的Bug之一 —— 某用户签到了两次

    1.故事背景 今天上午我忙完手中的事情之后突然想起来我还没签到,于是赶紧打开签到页面,刚点击了签到按钮,提示"签到成功,获得25阅读额度!",正准备退出浏览器,忽然发现签到列表有异 ...

  6. 【HIHOCODER 1323】回文字符串(区间DP)

    描述 给定一个字符串 S ,最少需要几次增删改操作可以把 S 变成一个回文字符串? 一次操作可以在任意位置插入一个字符,或者删除任意一个字符,或者把任意一个字符修改成任意其他字符. 输入 字符串 S. ...

  7. java中的equals与==的区别

    equals是Object类的公共方法,方法内部是用==实现的.但是很多类都重写了equals方法,例如基本数据类型的封装类和String类,重写后比较的是对象的值或者内容是否相同.而==是比较地址, ...

  8. document文档碎片

    var arrText = ["1","2","3","4","5","6",& ...

  9. Eclipse截取android报错log

    Eclipse截取android报错log: 1.前提条件:已安装eclipse 2. LogCat界面设置: Logcat是Android 编程中一个命令行工具,可以用于得到程序的 log 信息,可 ...

  10. JMeter学习笔记21-如何添加思考时间

    本文来介绍,JMeter如何插入思考时间.前面介绍过一个真实的性能测试场景,是需要加入思考时间,来模拟真实用户行为.本文就来介绍,如何在三个请求之间添加思考时间. 1. 在Test Plan下新建一个 ...