文章摘自:suchso.com/projecteactual/javascript-html5-css3-taobao-xiala-data.html

segmentfault.com/a/1190000004370220

原生app里的数据列表都会使用下拉刷新的效果,在webapp里可以采用iscroll、swiper等插件或框架实现,那么如何自己编码实现类似的效果呢,下面介绍使用原生js+css3实现的简单效果。

html布局

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
  6. <title>test</title>
  7. <style type="text/css" media="screen">
  8. body{margin: 0;}
  9. ul{list-style: none;padding: 0;}
  10. li{height: 30px;border-bottom: 1px solid #ddd;line-height: 30px;padding-left: 10px;}
  11. .scroller .loading{height: 60px;line-height: 60px;text-align: center;width: 100%;background-color: #f1f1f1;}
  12. .scroller{-webkit-overflow-scrolling:touch;}
  13. </style>
  14. </head>
  15. <body >
  16. <div id="container" class="scroller" >
  17. <div class="loading">
  18. 下拉刷新数据
  19. </div>
  20. <ul>
  21. <li><a href="#">列表数据1</a></li>
  22. <li><a href="#">列表数据2</a></li>
  23. <li><a href="#">列表数据3</a></li>
  24. <li><a href="#">列表数据4</a></li>
  25. <li><a href="#">列表数据5</a></li>
  26. <li><a href="#">列表数据6</a></li>
  27. <li><a href="#">列表数据7</a></li>
  28. <li><a href="#">列表数据8</a></li>
  29. <li><a href="#">列表数据9</a></li>
  30. <li><a href="#">列表数据10</a></li>
  31. <li><a href="#">列表数据11</a></li>
  32. <li><a href="#">列表数据12</a></li>
  33. <li><a href="#">列表数据13</a></li>
  34. <li><a href="#">列表数据14</a></li>
  35. <li><a href="#">列表数据15</a></li>
  36. <li><a href="#">列表数据16</a></li>
  37. <li><a href="#">列表数据17</a></li>
  38. <li><a href="#">列表数据18</a></li>
  39. <li><a href="#">列表数据19</a></li>
  40. <li><a href="#">列表数据20</a></li>
  41. <li><a href="#">列表数据21</a></li>
  42. <li><a href="#">列表数据22</a></li>
  43. <li><a href="#">列表数据23</a></li>
  44. <li><a href="#">列表数据24</a></li>
  45. <li><a href="#">列表数据25</a></li>
  46. <li><a href="#">列表数据26</a></li>
  47. <li><a href="#">列表数据27</a></li>
  48. <li><a href="#">列表数据28</a></li>
  49. <li><a href="#">列表数据29</a></li>
  50. <li><a href="#">列表数据30</a></li>
  51. </ul>
  52. </div>
  53. <body>
  54. </html>

js逻辑

  1. var slide = function (option) {
  2. var defaults={
  3. container:'',
  4. next:function(){}
  5. }
  6. var start,
  7. end,
  8. length,
  9. isLock = false,//是否锁定整个操作
  10. isCanDo = false,//是否移动滑块
  11. isTouchPad = (/hp-tablet/gi).test(navigator.appVersion),
  12. hasTouch = 'ontouchstart' in window && !isTouchPad;
  13. var obj = document.querySelector(option.container);
  14. var loading=obj.firstElementChild;
  15. var offset=loading.clientHeight;
  16. var objparent = obj.parentElement;
  17. /*操作方法*/
  18. var fn =
  19. {
  20. //移动容器
  21. translate: function (diff) {
  22. obj.style.webkitTransform='translate3d(0,'+diff+'px,0)';
  23. obj.style.transform='translate3d(0,'+diff+'px,0)';
  24. },
  25. //设置效果时间
  26. setTransition: function (time) {
  27. obj.style.webkitTransition='all '+time+'s';
  28. obj.style.transition='all '+time+'s';
  29. },
  30. //返回到初始位置
  31. back: function () {
  32. fn.translate(0 - offset);
  33. //标识操作完成
  34. isLock = false;
  35. },
  36. addEvent:function(element,event_name,event_fn){
  37. if (element.addEventListener) {
  38. element.addEventListener(event_name, event_fn, false);
  39. } else if (element.attachEvent) {
  40. element.attachEvent('on' + event_name, event_fn);
  41. } else {
  42. element['on' + event_name] = event_fn;
  43. }
  44. }
  45. };
  46. fn.translate(0-offset);
  47. fn.addEvent(obj,'touchstart',start);
  48. fn.addEvent(obj,'touchmove',move);
  49. fn.addEvent(obj,'touchend',end);
  50. fn.addEvent(obj,'mousedown',start)
  51. fn.addEvent(obj,'mousemove',move)
  52. fn.addEvent(obj,'mouseup',end)
  53. //滑动开始
  54. function start(e) {
  55. if (objparent.scrollTop <= 0 && !isLock) {
  56. var even = typeof event == "undefined" ? e : event;
  57. //标识操作进行中
  58. isLock = true;
  59. isCanDo = true;
  60. //保存当前鼠标Y坐标
  61. start = hasTouch ? even.touches[0].pageY : even.pageY;
  62. //消除滑块动画时间
  63. fn.setTransition(0);
  64. loading.innerHTML='下拉刷新数据';
  65. }
  66. return false;
  67. }
  68. //滑动中
  69. function move(e) {
  70. if (objparent.scrollTop <= 0 && isCanDo) {
  71. var even = typeof event == "undefined" ? e : event;
  72. //保存当前鼠标Y坐标
  73. end = hasTouch ? even.touches[0].pageY : even.pageY;
  74. if (start < end) {
  75. even.preventDefault();
  76. //消除滑块动画时间
  77. fn.setTransition(0);
  78. //移动滑块
  79. if((end-start-offset)/2<=150) {
  80. length=(end - start - offset) / 2;
  81. fn.translate(length);
  82. }
  83. else {
  84. length+=0.3;
  85. fn.translate(length);
  86. }
  87. }
  88. }
  89. }
  90. //滑动结束
  91. function end(e) {
  92. if (isCanDo) {
  93. isCanDo = false;
  94. //判断滑动距离是否大于等于指定值
  95. if (end - start >= offset) {
  96. //设置滑块回弹时间
  97. fn.setTransition(1);
  98. //保留提示部分
  99. fn.translate(0);
  100. //执行回调函数
  101. loading.innerHTML='正在刷新数据';
  102. if (typeof option.next == "function") {
  103. option.next.call(fn, e);
  104. }
  105. } else {
  106. //返回初始状态
  107. fn.back();
  108. }
  109. }
  110. }
  111. }
  112. slide({container:"#container",next: function (e) {
  113. //松手之后执行逻辑,ajax请求数据,数据返回后隐藏加载中提示
  114. var that = this;
  115. setTimeout(function () {
  116. that.back.call();
  117. }, 2000);
  118. }});

javascript+html5+css3下拉刷新 数据效果的更多相关文章

  1. 24个 HTML5 & CSS3 下拉菜单效果及制作教程

    下拉菜单是一个很常见的效果,在网站设计中被广泛使用.通过使用下拉菜单,设计者不仅可以在网站设计中营造出色的视觉吸引力,但也可以为网站提供了一个有效的导航方案.使用 HTML5 和 CSS3 可以更容易 ...

  2. 10个优秀的 HTML5 & CSS3 下拉菜单制作教程

    下拉菜单是一个很常见的效果,在网站设计中被广泛使用.通过使用下拉菜单,设计者不仅可以在网站设计中营造出色的视觉吸引力,但也可以为网站提供了一个有效的导航方案.使用 HTML5 和 CSS3 可以更容易 ...

  3. mui实现分页上拉加载更多 下拉刷新数据的简单实现 移动端下拉上拉

    空下来把mui上拉加载更多,下拉刷新数据做了一个简单的实现,希望可以帮助到需要的朋友 demo项目的结构 <!DOCTYPE html> <html> <head> ...

  4. 用mescroll实现无限上拉增加数据,下拉刷新数据 (学习笔记)

    最近自己做一个web app需要用到上拉查询下页数据,网上看了很多很多帖子,发现并不能快速的套用,总是会出现各种问题无法使用,于是无奈自己跑去看了官方api文档,终于做了出来,至此做个笔记,以后用到可 ...

  5. vue 下拉刷新数据的插件的使用:

    1.安装: npm i vue-scroller -S npm install vue-scroller -D 2.在需要加载的页面中引入,或在公共js文件中引入: import VueScrolle ...

  6. 11个优秀的HTML5 & CSS3下拉菜单制作教程

    下拉菜单是一个很常见的效果,在网站设计中被广泛使用.通过使用下拉菜单,设计者不仅可以在网站设计中营造出色的视觉吸引力,但也可以为网站提供了一个有效的导航方案.使用HTML5和CSS3可以更容易创造视觉 ...

  7. 手机端原生js实现下拉刷新数据

    HTML结构如下: <div class="outerScroller comment"> <div class='scroll comment'> < ...

  8. 高仿IOS下拉刷新的粘虫效果

    最近看需要做一款下拉刷新的效果,由于需要和Ios界面保持一致,所以这用安卓的方式实现了ios下的下拉刷新的粘虫效果. 最新的安卓手机版本的QQ也有这种类似的效果,就是拖动未读信息的那个红色圆圈,拖动近 ...

  9. Android 聊天表情输入、表情翻页带效果、下拉刷新聊天记录

    经过一个星期的折腾,最终做完了这个Android 聊天表情输入.表情翻页带效果.下拉刷新聊天记录.这仅仅是一个单独聊天表情的输入,以及聊天的效果实现.由于我没有写server,所以没有两方聊天的效果. ...

随机推荐

  1. xshell sftp可用命令,sftp: cannot open d: to write![解决]

    sftp可用命令: cd 路径 更改远程目录到“路径” lcd 路径 更改本地目录到“路径” chgrp group path 将文件“path”的组更改为“group” chmod mode pat ...

  2. 北京Uber优步司机奖励政策(4月11日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  3. 向大学说拜拜——大学 > 兴趣 + 时间 + 思考 + 实践

    [人物素描] 大学期间,担任过班委,加入过学生会,参加过社团,拿过奖学金......而印象最深刻的莫过于参加并组织过ACM集训,以及参加过导师的国家自然科学基金项目了.毕业时顺利拿到一波offer,并 ...

  4. Vue学习计划基础笔记(五) - 表单输入绑定、组件基础

    表单输入绑定.组件基础 目标: 熟练掌握vue中表单的处理方式 对之前学习的内容简单回顾一下,并写一个实例,学以致用(最好脱离文档) vue中表单的处理方式 vue中表单的处理使用了v-model指令 ...

  5. 001 -js对时间日期的排序

    001-JS对时间日期的排序 最近在做公司的项目时间,产品给了一个很简单的页面,让帮忙写一下.首先看一下产品的需求: 需要对该列表进行排序 思路:(1)可以在数据库写sql语句的时间直接一个DESC按 ...

  6. day03 作业 and 周末作业

    请输出 name 变量对应的值中 "e" 所在索引位置? # name = "leX leNb"# num = 0# while num < len(na ...

  7. 【python】详解time模块功能asctime、localtime、mktime、sleep、strptime、strftime、time等函数以及时间的加减运算

    在Python中,与时间处理相关的模块有:time.datetime以及calendar.学会计算时间,对程序的调优非常重要,可以在程序中狂打时间戳,来具体判断程序中哪一块耗时最多,从而找到程序调优的 ...

  8. ICPC 沈阳 Problem C

    题意 求n的全排列中将前k个数排序后最长公共子序列>=n-1的个数 思考 我们先把最后可能产生的结果找出来,再找有多少种排列能构成这些结果 设排列为s S like 1,2,3,...,n , ...

  9. New begin

    Purpose 今天更换了id,希望重新沉淀. 晚上看到国外一个博客,落款有个中文: 敬惜字纸. 共勉.

  10. Python 装饰器Decorator(一)

    (一) 装饰器基础知识 什么是Python装饰器?Python里装饰器是一个可调用的对象(函数),其参数是另一个函数(被装饰的函数) 假如有一个名字为somedecorator的装饰器,target是 ...